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SAFETY SUMMARY 


Genera! safety information for operating personne! is contained in this summary. !n addition, specific WARNINGS and 
CAUTIONS appear throughout this manual where they apply and are not included in this summary. 


Definitions 
WARNING statements identify conditions or practices that could result in personal injury or loss of life. 


CAUTION statements identify conditions or practices that could result in damage to equipment or other property. 


Symbols 


man : This symbol appears on the equipment and it indicates that the user should consult the manual for 
further detail. 


V “\: This symbol stands for Vac. For example, 120V Vv = 120 Vac 


Power Source 


Check the voltage selector indicator (located on the rear panel) to verify that the product is configured for the 
appropriate line voltage. 


Grounding the Product 

The product is grounded through the grounding conductor of the power cord. To avoid éleciric shock, piug the power 
cord into a properly wired and grounded receptacle only. Grounding this equipment is essential for its safe operation. 
Power Cord 


Use only the power cord specified for your equipment. 


Servicing 


To reduce the risk of electric shock, do not perform any servicing other than that described in this manual. 
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This manuai describes the componenis and operation of 
the 29B. Subjects addressed in this manual and the 
corresponding sections are listed in table 1-1. Use this list 
as a quick-reference point of the major sections in this 
manual. 


1.7 INTRODUCTION 

Data |/O’s 29B Universal Programmer utilizes moduiar 
programming paks io reliably program most commercially 
available programmable memory and logic devices. The 


beeen BNA 
ir ode. code and pincut code tabie at the back of the Pak 


anual lists the devices (by manufacturer). 


Standard features of the 29B include a 64K x 8 data RAM, 
an RS232C serial port and a 16-character alphanumeric 
display. The 29B also offers 27 data translation formats 
which enable you to communicate between the 29B and 
development systems, such as Texas Instruments, 
Motorola, intel, Tektronix, Signetics, Fairchild, RCA and 
Hewlett-Packard. In addition, the standard system includes 
two remote control protocols. The Data I1/O Computer 


Table 1-1. Using the 29B Manual 


SUBJECT 
Safety Summary 


Pak Installation 
Power Connection 
Serial 1/O Interface 


SECTION 


Front of manual 
2.2 
2.4 
2.5 


Remote Control (CRC) communication protocol provides POWEEUP 3.2 
CRC tion that is compatible with other Data |/O Power-Down 3.3 
Sean ected Conary Manual Keyboard Operations 3.4 


products. System Remote Control (SRC) utilizes a simple 
command protocol that is similar to the syntax featured in 
the 29B front panel control to initiate rapid start-up in 
remote operation. Both of these remote-control features 

e fully documented in section 3 (Oneration). 


The 29B also offers the following optional features. If you 


Selecting the Family and Pinout 
Codes 

Device Insertion 

Source/ Destination Method of 
Syntax 

Front Panel Keyboard Data 


See Pak Manual. 
3.4.2 


wo 


wish to purchase any of these features, contact your Transfer Operations 3.6 
nearest Data I/O sales representative; a list of sales Edit Data 3.7 
representatives is provided at the back of this manual. Perform a Select Function 3.8 
¢ Terminal Remote Controi (TRC)—an optional package, i Bermots Operations 30 


compatible with Data |/O’s System 1903. Maintenance of 298 


Maintenance of Pak See Pak manual. 
Calibration of 29B Power Supplies 4.3.1 

Calibration of 29B and Pak See Pak Manual. 
Troubleshooting 29B 4.4 
Troubleshooting Pak See Pak Manual. 


¢ Handler Interface—an optional feature that allows you 
to connect the 29B to a Deita or MCT device handier. 
The combination of a 29B, Handler UniPak™, and 
device handler enables you to program large quantities 
of both MOS (metal oxide semiconductor) and bipolar 
PROMs (programmable read only memories) with 


minimum operator handling. Section 5 


Circuit Description 


Data Translation Formats 

NOTE Terminal Remote Control 
Although other programming Paks can Optional Handler Interface 
be used, neither the Pak/handler Reference Material 
interface nor the 29B Handler port cable Error Codes 
is provided. The Handler port is required. Schematics 
Data |/O Service Centers 
Warranty Information 


Appendix A 
Appendix B 
Appendix C 
Appendix D 
Appendix E 
Appendix F 
Back of Manual 
When using the Exatron 2500 handler, the optional handler Back of Manual 
interface is not necessary and other programming paks 
(other than the Handler UniPak™) can be used. Exatron 
provides the interface necessary for operation with the 29B. 


e Serial Paper Tape Reader (950-1950)—can be used to 
transmit data from a paper tape io your 29B. 
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Throughout this manual, the entries that you are to make 
from either the programmer or a terminal are indicated by 
an equipment symbol and key symbol. For example, 


‘ \aeao— 
= 
"Aimee 

29B 


indicates the ‘‘COPY” key on the programmer keyboard 
should be pressed. In addition, the symbols shown below 
are used to indicate terminal operation, prompts that will 
appear on the CRT, or prompis that will appear on the 
programmer display. 


a 


TERMINAL 


29B DISPLAY 
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1.2 SYSTEM OVERVIEW 


The 29B provides a universal means of programming, 
testing, and verifying a variety of memory and logic 
devices. You can tailor the 29B to your programming needs 
by selecting the appropriate programming Pak and plugging 
it into the 29B. The various programming components from 
which you can choose to complete your programming 
system are listed below and shown in figure 1-1. 


UniPak 2™— programs more than 600 devices, including 
MOS and CMOS EPROMs and EEPROMs, fuse link, 
AIM and DEAP bipolar PROMs. Programming 
algorithms are software selectable and no additional 
personality modules are required. Simple pinout adapters 
are available for 40-pin microcomputers and parts with 
non-standard pinouts. 


LogicPak™ — combined with appropriate plug-in 
adapters, allows you to design, program and 
functionally test more than 80 different logic devices. 
The high-level software translates your logic design from 
truth tables or Boolean equations into the correct fuse 
map. 


GangPak™-— gives you the capability of programming, in 
a single operation, identical sets of MOS EPROMs or 
EEPROMs. Set programming allows you to partition a 
program into one or more sets of PROMs. The 
GangPak™ can also be used for conventional gang 
programming of up to eight devices at a time. 


MOSPak™/-— programs more than 145 MOS EPROMs 
and EEPROMs, requiring no additional hardware. 


a, 
Senet, 
ee 
a 


29B PROGRAMMER REMOTE CONTROL* 

Base unit with keyboard; accepts Paks; contains The standard Computer Remote Control (CRC) allows 

control electronics. 29B also contains standard you to save programs on disk or tape which may be 

System Remote Controi (SRC) and Computer downloaded to the 29B. System Remote Contro! 

Remote Control (CRC) software. An optional handler (SRC) allows you to send commands to the 29B 

interface can be used for fast, high-volume from a terminal, and an optional Terminal Remote 

programming of MOS and bi-polar PROMs. Control (TRC) is a terminal remote mode which is 
compatible with that used in System 19 
programmers. 

PROGRAMMING PAKS *Terminal not included. 


LogicPak™ UniPak 2™ GangPak™ 
Combined with appropriate plug- Programs more than 600 popular Programs multiple MOS PROM 
in adapters, the LogicPak™ bipolar PROMs, MOS EPROMs, sets and gang programs MOS 
allows you to design, program and MOS EEPROMs. PROMs for high-volume 
and functionally test more than programming operations. 

80 logic devices. 
PROGRAMMING MODULES 
Support device family 
applications not covered by 
programming Paks. 

MOSPak™ 
Programs more than 145 MOS 

| EPROMs and EEPROMs with no 


additional hardware changes. | 


Figure 1-1. 29B System Components 
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1.3 INTRODUCTION TO OPERATION uses are discussed in the following subsections and shown 
in figure 1-2. Section 3 (Operation) provides specific step- 
by-step instructions on how to execute the operations 
listed in the following subsections. 


With the 29B, you can perform four basic operations (listed 
below) by using the four dedicated mode (operation) keys 
on the front panel keyboard. These mode keys and their 


DISPLAY: 


Displays the current status 
of the programmer. 


SOURCE/DESTINATION KEYS: 


These keys can be used to specify 
either the data’s source or destination. 
They work in conjunction with the 
COPY and VERIFY keys. Refer to the 
source/destination concept of data 
transfer and verification as explained 
in section 3.6. 


REVIEW KEY: 


Gives the programmer backwards 
“stepping” capability through Select 
Functions, edit addresses and 
calibration steps. Also provides a 
delete function when entering 
parameters. 


START KEY: 


Commands the programmer to 
execute the operations selected 
and sends entered hex values 
in edit mode, to memory. Also 
gives the programmer forward 
“stepping” capability through 
select function, edit addresses, 
HEX KEYBOARD: MODE KEYS: format menu and calibration 


Allows entry of COPY SELECT step. 
hexadecimal 


values. 


Used to move a block of data Prepares the programmer to 
to or from a serial port, RAM, accept codes for Select 

or device. Works in conjunction Functions. See section 3.5. 
with source/destination keys. 


EDIT 


VERIFY Allows viewing and changing 
Used to make a byte-by-byte of data at individually selected 
comparison of a block of data. RAM address locations. See 
Used with source/destination section 3.4.10. 

keys. 


Figure 1-2. 29B Front Panel Functions 
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1.3.1 TYPICAL 29B OPERATION 


COPY (Data Transfers) 


zh 
5 
) 
5 
D 


RAM location i aie: use the COPY ha Whe en you 
press the COPY key, the programmer moves daia from the 
source (a device, the programmer RAM, or the serial port) 
to the destination (a device, the programmer RAM, or the 
serial port); for example, from the programmer data RAM 
te a blank device in the socket. At the completion of this 
operation, the device is programmed; that is, it contains a 
copy of the data in the programmer RAM. The 

“‘source/ destination’ concept is explained in section 3.5. 


There are five basic types of copy operations. These 

operations are summarized below and described in detail in 

section 3. 

e Load RAM with Master Device Data—transfers 
programming data from a master device and to the 
programmer RAM. When the data transfer is complete, 
the 29B calculates and displays the sum-check (see 
Glossary for definition) of the loaded data. 


¢ Load RAM from Serial Port—translates data received at 
the serial port and transfers it to the programmer RAM. 
When completed, the programmer calculates and 
displays the sum-check of the data. If a sum-check has 
been sent with the data from the serial port, the 
programmer will compare the two and signal an error if 
they do not match. 


e Program—puts the data in the programmer RAM into a 
device. Programming is automatic, starting with an 
illegal-bit test and a blank check to ensure that the 
device can be programmed. Data is then programmed 
into the device in the socket one byte at a time. This 
continues until all data bytes have been programmed 
into the device. After programming is completed, the 
data in the device is automatically compared with the 
RAM data to ensure correct programming. 


e Output RAM to Serial Port—translates data from the 
programmer RAM and transfers it to the serial port. 


¢ Block move—rearranges blocks of data within RAM. 


VERIFY (Data Verification) 


The VERIFY key is used to make a byte-by-byte 
comparison of data in two locations, one referred to as the 
“source” and one as the “destination”: see section 3-5 for 
details. There are two types of Verify operations. 


e Verify Device—compares data twice from the device 
(the destination) byte-by-byte with the data in RAM (the 
source). On the first pass (first comparison), the 29B 
checks the parameters by lowering Vcc within the 
manufacturer’s specified lower level. On the second 
pass, VCC is raised to the upper level specification 
rafige. 

© Verify RAM from Serial Port— compares incoming data 
from the serial port byte-by-byte with the data in RAM. 
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EDIT (Editing Data) 


The EDIT key allows you to view and change data at 
specified RAM addresses. Section 3 provides specific 


details 


el Wee wenn 


The SELECT key aiiows you to change certain operationai 
parameter default values, perform RAM data manipulations, 
and access certain less frequently used operations. These ~ 
operations are referred to in this manual as Select 
Functions. Detailed Select Function information, including 
operation, is located in section 3.8. 


1.3.2 SAMPLE 298 PROGRAMMER OPERATION 
WITH UNIPAK™ 


The 29B is a versatile tool for programming data into blank 
devices. Figure 1-3 illustrates the process of programming 
data from RAM into a blank device by using the 
programmer’s front panel keyboard. {n this example, the 
source of data is a master device; however, data can also 
be input from the programmer keyboard or through the 
serial port. 


When using a master device as your source of data, you 
need only a few steps to program this data into a blank 
device. With the appropriate pak installed (section 2.2) and 
the machine powered on (section 2.4), the steps you need 
to perform this operation are provided below and 
diagrammed in figure 1-3. 


WARNING 
Refer to the safety instructions of 
section 2.4 before powering up the 
29B. 


1. Press: COPY + DEVICE + RAM + START. 


2. Enter the family and pinout codes for your device. 
These codes are included in your Pak manual. 


. Insert the master device into the appropriate Pak socket. 
. Press START. 
. Remove master device from the socket. 


. Press: COPY + RAM + DEVICE + START. If the 
device to be programmed has different family and 
pinout codes from the master, enter the correct codes. 
Otherwise, go to the next step. 


ao oo -& W 


7. Insert the blank device into the appropriate Pak socket. 
8. Press START. 


Step 8 will initiate an illegal-bit and blank check test (see 
Glossary) of the device followed by the programming and 
verify sequence. The programmer will signal you when the 
device has been programmed. 
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BEGIN 


INSTALL 
UNIPAK 2 
(SECTION 2) 


TURN ON 
PROGRAMMER 
(SECTION 3 2) 


PRESS COPY 
DEVICE 
RAM 
START 

(SECTION 3 4) 


ENTER FAMILY 
AND PINOUT 
CODES 
(SECTION 3.4.1) 


INSERT MASTER 
DEVICE IN 
SOCKET 
(SECTION 3.4.2) 


REMOVE MASTER 
DEVICE 
(SECTION 3.4.3} 


PRESS COPY 
RAM 
DEVICE 
START 
(SECTION 3 4) 


CORRECT 


ENTER 


FAMILY AND FAMILY AND 
PINOUT ENTERED PINOUT CODE 
(SECTION 3.4.1) 


INSERT 
BLANK DEVICE 

TO BE PROGRAMMED 

(SECTION 3 4.2) 


PRESS 
START 

(THIS WILL START 
PROGRAM 
OPERATION) 


REMOVE 
PROGRAMMED 
DEVICE 
iSECTION 3 4 3} 


PROGRAM 
ADDITIONAL 
PARTS 


Sy 


Figure 1-3. Sample 29B Programmer Operation 
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After data have been loaded into RAM from the serial port 
or the master device, the programmer calculates the sum- 
check of the data (figure 1-4) and displays it (when in 
terminal mode, it will be displayed on the terminal). The 
sum-check, which is used to verify the integrity of data 
transfers, is a summation of 8-bit bytes of fuse data 
expressed as a 4-digit hexadecimal number (see figure 1-4). 


10000100 
11000001 
01100010 
00100100 


0000 0001 1100 1011 
BINARY DATA 


Sixteen-bit binary 
sum-check 


HEX DATA 


Sum-check in 
hexadecimal notation 


Figure 1-4. Sample Sum-Check Calculation 


If data were loaded through the serial port and a sum- 
check was sent with it, the programmer will compare the 
sum-check with its own calculation. If they agree, the 
correct sum-check is displayed. If they do not agree, the 
programmer will signal an error. Data from the seriai port 
will also be checked for correct parity if the program parity 
switch is on (see subsection 2.5.2). 


The System 19, 100A, 29A, and 29B programmers have a 
data-lock feature that allows you to limit the accessibility of 
your RAM data. This is useful in production environments 
to protect the integrity of your RAM data. Refer to section 
3 for information on data lock. 


For a program operation with the 29B programmer, 
programming is automatic and starts with a series of tests: 
backward device test, illegal-bit test, and blank check. 
During the backward device test, the programmer 
automatically checks the device’s orientation in the 
programmer module’s socket(s) and displays an error if it is 
inserted backwards. The 29B displays: 
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The illegal-bit test checks for previously programmed bits in 
a nonblank device that cannot be programmed according 
to the data in RAM. If illegal bits exist, 

the 29B displays: 


During the blank check, the programmer searches the 
device for programmed bits. If any are found (and the bits 
are legal), the programmer will signal the operator and 
the 29B displays: 


No BLANK 


Nonbiank parts can be over-programmed by again pressing 


—— 
ee 
fo 


if the device passes these tests, data are transferred from 
the programmer RAM to the Pak one byte (eight fuse 
states) at a time. The Pak then applies the programming 
pulses to the first fuse and tests its condition. If the 
address fails to program, the 29B displays: 


ra 
20 


Otherwise, programming proceeds to the next address until 
all have been programmed; with some P/T adapters, 
programming algorithms vary and may display only a verify 
error. Refer to the Pak manuals for manufacturer-specific 
programming algorithms and waveform pictures. 


1.3.3 REMOTE OPERATION 


The 29B can also be operated in remote control. Computer 
Remote Control (CRC) and System Remote Control (SRC) 
are explained in section 3 (Operation). An optional Terminal 
Remote Control (TRC), compatible with System 1903, is 
documented in appendix B. 
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1.4 SPECIFICATIONS 


The 29B’s specifications are listed below. 


1.4.1 FUNCTIONAL SPECIFICATIONS 


Functional specifications for the 29B are as follows: 


General Architecture: Microprocessor controlled (6808) ° 


Data RAM: 64K x 8 


Programming Support: GangPak™, LogicPak™, 
UniPak 2™, MOSPak™ and programming modules 


Keyboard: 16-key hexadecimal and 9-key functional 


Display: 16-character alphanumeric 


Input/Output: Serial RS232C and 20 mA current loop 


Baud Rates: 50, 75, 110, 134.5, 150, 300, 600, 1200, 
1800, 2000, 2400, 3600, 4800, 7200, 9600, 


19,200 


Remote Control: Computer Remote Control (CRC), 
System Remote Control (SRC), 
Optional Terminal Remote Control (TRC) 


Translation Formats: See table 1-2. 


Handler Capability: Optional handler port is available for 
binning and control signals. 


Table 1-2. Available Translation Formats for the 
29B Universal Programmer 


ASCII-B10F 
ASCII-BHLF 
ASCII-BNPF 

ASCll-Hex (Apostrophe) 
ASCIl-Hex (Comma) 
ASCIl-Hex (Percent) 
ASCIl-Hex SMS 
ASCIl-Hex (Space) 


ASCIll-Octal (Apostrophe) 
ASCIil-Octal (Percent) 
ASCII-Octal SMS 
ASCIll-Octal (Space) 
Binary 

BNPF (5-Level) 


DEC Binary 

Fairchild Fairbug 
Hewlett-Packard 64000 Absolute 
Intel Intellec 8/MDS 

Intel MCS-86 Hexadecimal 
Object 

MOS Technology 

Motorola Exorciser 

Motorola Exormax 

RCA Cosmac 

Signetics Absolute Object 
Spectrum 

Tektronix Hexadecimal 

Texas Instruments SDSMAC 
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1.4.2 POWER REQUIREMENTS 
Power requirements for the 29B are as follows: 


¢ Operating Voltages: 100, 120, 220 or 240 Vac + 5% or 
— 10%. 


e Frequency Range: 50 + 2 Hz or 60 + 2 Hz for 100V 
and 120V units, 50 + Hz for 220V and 240V units. 


¢ Power Consumption: 115W/175 VA 


e Fuse Protection: primary and secondary fuse protection 


1.4.3 PHYSICAL AND ENVIRONMENTAL 


Physical and Environmental Requirements for the 29B are 
as follows: 


¢ Dimensions: 31.1 x 15.2 x 27.3 cm (15 x 6 x 10.8 in.) 
e Weight: 6.4 kg (14.1 Ib) 

¢ Operating Temperature: +5° to 45°C (41° to 113°F) 

e Storage Temperature: — 40° to 70°C (—40° to 158°F) 
¢ Humidity: to 95% (noncondensing) 

¢ Operational Altitude: to 10,000 ft. 


1.5 FIELD APPLICATIONS SUPPORT 


Data I/O has field applications engineers (FAEs) who can 
provide you additional information about interfacing 

Data 1/0 products with other equipment and answer your 
questions about problems you may have with your 
equipment. The location of the FAE nearest you is given in 
the back of this manual. Call your FAE if you have any 
questions or problems. 


1.6 WARRANTY 


Data I/O equipment is warranted against defects in 
materials and workmanship. The warranty period is one 
year and begins when you receive the programmer. The 
warranty card at the back of this manual explains the 
length and conditions of the warranty. For warranty 
service, contact your nearest Data I/O Service Center. 


10-990-0013 


1.7 SERVICE 


Data I/O maintains Service Centers throughout the world, 
each staffed with factory-trained technicians to provide 
prompt, quaiity service. A iist of aii Service Centers is 
located at the back of this manual. In addition to making 


If you must ship the 29B to the Data |/O factory or a 
Service Center for servicing, do the following: 


1. Contact the Service Center to let them know you will be 
sending in equipment. 


2. Attach a tag to the equipment, describing the work 
required and identifying the owner and the purchase 
order number for the servicing. 


3. Wrap the instrument with heavy paper or plastic. 


4. Place it in the original shipping container or some other 
suitable heavy carton with foam packing material and 
seal the container with strong tape. 


5. Mark the container ‘DELICATE INSTRUMENT” and 
“FRAGILE.” 


In correspondence, identify the unit by serial number, 
model number and name. 


For more information about servicing Data |/O products, 
contact your nearest Data 1/O Service Center or sales 
represeniative. 
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1.8 ORDERING 


To place an order for equipment, contact your Data I/O 

representative. Orders for shipment must include the 

foiiowing: 

e Description of the eauinment (see latest Data |/O price 
list or contact your sales representative for equipment 
and part numbers). 


¢ Purchase order number 

e Desired method of shipment 

e Quantity of each item ordered 

e Shipping and billing address of firm, including zip code 


e Name of person ordering equipment 
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SECTION 2 


INSTALLATION 


2.1 INTRODUCTION 


This section describes how to set up your programmer for 
operation. For best results in getting your programmer 
ready for use, we suggest that you foiiow the procedures 
described in the following subsections. 


® Pak Installation (section 2.2) 
e Power Connection (section 2.4) 


¢ Power and Fuse Requirements (sections 2.4.1 through 
2.4.4) 


e Serial |/O Interface (section 2.5) 


Your 29B was thoroughly calibrated, tested, and inspected 
before shipment. The unit was carefully packaged to 
prevent damage and should arrive free of any defects and: 
in perfect operating condition. Carefully inspect it for any 
damage that may have occurred during transit. If you note 
any damage, file a claim with the carrier and notify 

Data 1/0. 


Check to make sure that you have received the following 
‘required equipment: 


Item Part Number Quantity 


¢ 29B Universal Programmer 990-0013 1 

© Power Cord 1 
-Europe 416-0010 
-USA/Canada/Japan 418-1577 

© Serial Port Mating Connector 401-3064 1 

© Serial Port Connector Hood 401-3069 1 

© Operator's Guide 12-990-0013 1 


Check the operation of the unit after you have completed 
the installation instructions in this section. 
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2.2 PAK INSTALLATION — 


Any of the Data !/O programming Paks may be instaiied 
and removed with the programmer's power on; this feature 
allows you ic retain data in the 298 RAM when changing 
programming Paks. If the programmer power is turned on 


7 —™ 2» « ss = '5 a a8 as nm F og am dead a 
before a Pak is instalied, you will hear a “beep” until the 


Pak is properly installed. 


CAUTION 
Voltage transients can cause device 
damage. Be sure that all sockets are 
empty when switching power on or 
off or installing or removing the Pak. 


To install a Pak into the 29B, refer to figure 2-1 and follow 
this installation procedure. 


1. Slide the Pak into the opening in the programmer. 


2. Tilt the Pak up, and gently push it back to hook its 
flange over the top back edge of the programmer 
opening (figure 2-1a). 


3. Lower the Pak into position as shown in figure 2-1b. 


CAUTION 
Be careful when inserting the Pak. If 
the connector at the bottom of the 
Pak (see figure 2-1b) has bent contact 
pin(s), forcing the Pak couid break 
the pin(s) or damage the connector. 


4. Press down gently on the front edge of the Pak to 
ensure a good connection (figure 2-1c). 


10-990-0013 


FLANGE 


2-1a) Tip the programming pak up and back to 
lock flanges. 


2-1c) Push down to lock programming pak into 
place. 


NOTE: Although the GangPak™ is shown 
here, the insertion procedure is the 
same for all programming paks. 


Figure 2-1. Installing/Removing a Programming Pak 
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2.3 PAK REMOVAL 
To remove the Pak from the 29B: 


1. Check to make sure the programmer is not in the 
middle of an operation. If it is, wait until the operation 
is complete. The operation is complete when the action 
symbol on the display disappears. 


2. Check to make sure a device is not in a socket. If one is 
in a socket, remove it as described in subsection 3.4.3. 


3. Tilt the front portion of the Pak up and gently remove it 
from the programmer. : 


2.4 POWER CONNECTION 


Before applying power to your programmer, make sure that 
the operating voltage is correct (section 2.4.1), that the line 
fuse is intact (section 2.4.2), and that the unit is properly 
grounded (section 2.4.4). Finally, connect your power cord 
and apply power to the programmer (section 2.4.5). 


2.4.1 VERIFYING/CHANGING THE OPERATING 
VOLTAGE 


The factory has selected the proper voltage according to 
your specification. A voltage reading is visible through a 
window in the door that covers the voltage wheel selector, 
located on the back panel, as shown in figure 2-2. This 
voltage should be the same as the line voltage on which 
the machine will operate. If the voltage that appears in the 
window is incorrect, change the operating voltage 
according to the following procedure. 


CAUTION 
This instrument may be damaged if 
operated with the wrong line voltage. 


DOOR COVERING 
VOLTAGE WHEEL SELECTOR 


Ale 


AC 
POWER 
PLUG 


WINDOW 


PROGRAMMER 
BACK PANEL 


Figure 2-2. Back Panel 
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The procedures to verify and or change the operating 4. Insert the selector back into its slot. 
voltage are described here and illustrated in figure 2-3. 


1. Gently pry open the door that covers the voltage wheel NOTE 


selector with a flat-blade screwdriver (figure 2-3a). 


NE nies tgrinls Bs anna thin Wit £552. 28 ets 
iW you wistl tu access wie une 1uUse at Gus 
point, proceed to step 2 in section 2.4.2. 


NO 


. Puli the voltage wheei selector out of its siot 


(figure 2-3b). 5. Snap the door closed. 
3. Rotate the selector until the correct operating voltage 6. The correct voltage reading will now appear in the 
points toward you (figure 2-3c). window (figure 2-3d). 


VOLTAGE WHEEL 
SELECTOR 


voltage wheel selector, 


2-3a) Pry open door covering 2-3b) Pull out selector. 
1 using a flat-blade screwdriver. 


w 


/ 
S& 7 / 2-3c) Rotate selector until the 2-3d) Voltage reading through 
f . . 
SK correct operating voltage window should be the 


VOLTAGE READING | | 
— 
reading points toward you. same as the line voltage. 


Figure 2-3. Voltage Wheel Selector 
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2.4.2 VERIFYING/REPLACING THE LINE FUSE 


The line fuse is located behind the same door that covers 
the voltage wheel selector. After you determine that your 
298 is set to the proper operating voltage, perform the 
following procedure to verify that the line fuse is correct 
and intact. In the event that the fuse is blown, replace it 
with one of the correct size. Procedure steps are illustrated 
in figure 2.4. 


1. Gently pry open the door that covers the fuse holder 
using a flat-blade screwdriver (figure 2-4a). 


NOTE 
There are two fuse receptacles; only the 
one on the bottom is connected to the 
programmer's circuitry. The top 
receptacle is a spare fuse tray. See the 
next subsection (2.4.3) for more 
information on this spare tray. 


2. Pull the bottom fuse holder out of its slot (figure 2-4b). 


Check to determine whether the fuse is intact. If it is 
intact, proceed to step 4. If it is blown, install a new 
fuse. See table 2-1 for line fuse ratings. 


CAUTION 
For continued protection against the 
possibility of fire, replace only with a 
fuse of specified voltage, current and 
type ratings. 


Table 2-1. Line Fuse Ratings 
Line Fuse Rating 


Current Voltage 


Operating 
Voltage 


slow-blowe) 
slow-blowe) 
slow-blowb) 
slow-blow) 


416-1240-001 
416-1240-001 
416-1571-001 
416-1571-001 


{a)Littlefuse type 313," Bussman type “MDA” 
(b)Littlefuse type ‘'218,'" Bussman type “GDC,” Schurter 
type “001-2504.” 


. Insert the fuse holder into its slot so that the arrow on 
the fuse holder points in the same direction as the 
arrows on the door (figure 2-4c). 


5. Snap the door closed. 


2.4.3 SPARE LINE FUSE TRAY 


All 29B programmers are equipped with two line fuse trays 
(see figure 2-4 (b)). The white fuse tray accepts 1/4 x 1 
1/4 inch fuses; the black tray accepts 5 x 20 millimeter 
fuses, commonly available in Europe. Only the right-hand 
fuse receptacle is connected to the programmer's circuitry. 


Data 1/0 
Type Part Number 


2-4a) Pry open door that covers 
fuse holder using a 
flat-blade screwdriver. 


2-4b) Pull out fuse holder. The 
bottom fuse holder is 
used, the top fuse 
holder is not. 


2-4c) Reinsert fuse holder so 
that arrow on fuse 
holder points in same 
direction as arrows on 
door. 


Figure 2-4. Accessing the Line Fuse 
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2.4.4 GROUNDING THE UNIT 


The 29B is shipped with a three-wire power cable. This 
cable connects the chassis of the unit to the earth ground 
when the cable is connected to a three-wire (grounded) 
receptacle. 


| 
Wenn 


WARNING 
Continuity of the grounding circuit is 
vital for the safe operation of the 
unit. Never operate this equipment 
with the grounding conductor 
disconnected. 


2.4.5 APPLYING POWER 


Now that you have verified the programmer's voltage 


setting, fuse and grounding, you are ready to apply ac PROGRAMMER POWER CORD 
power. Follow this procedure: BACK PANEL CONNECTOR 


1. Check to make sure a device is not plugged into any 
Pak socket. If a device is in a socket, flip up the 
socket’s locking arm and remove the device from the 
socket. See subsection 3.4.3. 


Figure 2-5. Programmer Power Switch Location 


2. Connect to ac power by plugging the power cord into 
the back panel and into an ac receptacle. 


3. Press the power switch to the ON position; figure 2-5 © 
shows the power switch location and indicates the ON 
position. 
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2.5 SERIAL I/O INTERFACE 


An RS232C serial port interface is used to connect the 29B 
to computer systems and other peripherals. This requires 
installing the proper serial interface cabling and setting the 
appropriate operational parameters. 


NOTE 
Any computer or any other peripheral 
device that interfaces to the 29B’s serial 
port must allow for duplex operation 
consistent with the 29B programmer's 
remote control software. System remote 
control (SRC) and computer remote 
control (CRC) are half duplex, whereas 
terminal remote control (TRC) is full 


duplex. 
PROGRAMMER TERMINAL 
GROUND GROUND 
SEND DATA SEND DATA 


RECEIVE DATA 
REQUEST TO SEND 
CLEAR TO SEND 


SIGNAL GROUND 


RECEIVE DATA 


REQUEST TO SEND 


CLEAR TO SEND 


SIGNAL GROUND 


2.5.1 CABLING 


To connect the 29B to other instruments, you must use 
the serial interface connector pin assignments called out in 
table 2-2; figure 2-6 shows sample interconnections in the 
serial interface for half/full duplex with handshake (figure 
2-6a) and without handshake (figure 2-6b) and current loop 
connection for full duplex (figure 2-6c) and half-duplex 
(figure 2-6d). See figure 2-7 for the location of the RS232C 
serial port connector. 


NOTE 
To reduce electromagnetic interference 
(EMI), we recommend using a shielded 
cable. 


PROGRAMMER TTY 
GROUND 


SIGNAL GROUND 


RECEIVE DATA 
20 mA SEND 
20 mA RECEIVE 


20 mA DETECT 


2-6c) 20 mA Current Loop Connection, Full Duplex 


2-6a) RS232C Connection, Half/Full Duplex, with Handshake 


PROGRAMMER TERMINAL 
GROUND GROUND 
SEND DATA SEND DATA 


RECEIVE DATA 


SIGNAL GROUND 


2-6b) RS232C Connection, Half/Full Duplex, 
without Handshake 


NOTES: 


1, All signals are named with respect to the originating 


unit. 
2. All undesignated pins are to be left open. 


RECEIVE DATA 


SIGNAL GROUND 


PROGRAMMER TTY 


GROUND 


SIGNAL GROUND 
RECEIVE DATA 
20 mA SEND 

20 mA RECEIVE 


20 mA DETECT 


2-6d) 20 mA Current Loop Connection, Half Duplex 


3. For applications that do not require handshaking, the 
programmer's clear to send line is pulled up internally. 


Figure 2-6. Sample Interconnection Methods 
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Tabie 2-2. Seriai interface Connector Pin Assignments 


PIN | SIGNAL | 
| NO. | MNEMONIC | DESCRIPTION 


12 


Ground 


Send Data 


Receive Data 


Request to 
Send 


Clear to 
Senda) 


Data Set 
Ready 


Signal 
Ground 


Carrier 
Detecta) 


+24 Vde 


20 mA 
Send 


20 mA 
Receive 


Detect 


Data 
Ready 


+5 Vde 


Provides a safety ground connection. 


Transmits data within RS232C voltage levels (+12V and —5V). 
Accepts data within RS232C voltage levels. 


This line is normally held high by the programmer. It is dropped 
to inhibit data transmission from a remote source. 


A high level on this line allows the programmer to transfer data. A 
low level inhibits data transfer. 


Connected by internal jumper to Data Ready (pin 20). Simulates 
indication that the programmer is operating. 


This line provides a common signal connection to the RS232C 
remote source. 


This line is positive when modem detects a carrier signal. The line is 
is sampled by the programmer if used. 


Available for external use if required (500 mA maximum). 
Not used, 


Transmits data using active 20-mA current loop. 


Accepts data using active 20-mA current loop. 


20-mA receive data (pin 12) is internally converted to RS232C levels. 
Output on pin 13 should be jumpered externally to receive data 

(pin 3). 

Not used. 

Connected by internal jumper to data set ready (pin 6). A high level 
on this line from the RS232C data terminal indicates that the data 
terminal is ready. 


Not used. 


Available for external use if required (200 mA maximum). 


Available for external use if required (200 mA maximum). 


Not used. 


{al Pins 5 and 8 have internal pull-ups and need no connection if unused: 
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2.5.2 SETTING PARAMETERS 


Before the 29B can operate with another system, three 
parameters must be set: parity, stop bits and the baud 
rate. These parameters must be the same for both 
systems. 


Baud Rate 


To set the baud rate, refer to figure 2-7 and follow this 
procedure: 


1. Locate the baud rate rotary switch on the programmer's 
rear panel. 


2. Locate the desired baud rate on the chart in figure 2-7 
and the switch position required for that baud rate. 


3. With a flat-blade screwdriver, turn the switch to the 
numbered switch position that corresponds to your 
desired baud rate. 


PROGRAMMER 
BACK PANEL 


RS232C 
SERIAL PORT 
CONNECTOR 


BAUD RATE SWITCH 


1 
2 
3 
4 
5 
6 
7 
8 
9 


Figure 2-7. Baud Rate Switch and RS232 Serial Port 


Parity and Stop Bits 


To set parity and stop bits, refer to figure 2-8 and follow 
this procedure: 


CAUTION 
Make sure that all device(s) have 
been removed from the Pak socket(s) 
before removing the Pak or turning 
off the programmer. Voltage 
transients caused by removing the 
Pak could damage the device(s). 


1. Turn off programmer. 


NO 


. Remove the Pak from the programmer (see 
subsection 2.3). 


3. Access the controller board’s status switch (U53) 
through the cut-out in the lower right corner of the 
protective shield. See figure 2-8. 


4. Flip the switches to the desired setting; figure 2-8 
shows the switch positions set by the factory. 


5. Reinstall the Programming pak and turn on the 
programmer. 


TOP VIEW 


PARITY (OFF-ODD, ON-EVEN) 
PARITY (OFF, ON) ° 
STOP BITS (OFF-2, ON-1) 


NOT USED 


‘STATUS SWITCH U53 


Figure 2-8. Status Switch Setting 
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2.5.3 HOOKING UP A SERIAL PAPER TAPE READER 


A Data I/O Serial Paper Tape Reader (950-1950) can be 
connected to your programmer. A direct connection, to the 
programmer's serial port, is made using the existing serial 
paper tape reader cable. It will connect according to the 
specifications in figure 2-9. Set the baud rate at 2400. Two 
operations are possibie using the serial paper tape reader: 
load RAM from the serial port and verify RAM from the 


serial port. 
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SERIAL PAPER 
TAPE READER 
(950-1950) 


GROUND j: H#—{" ] GROUND 


{ 

PROGRAMMER | 

i i i I | 

RECEIVE DATA 3 | SEND DATA 


— 


REQUEST TO SEND 4 j} CLEAR TO SEND 


SIGNAL GROUND SIGNAL GROUND 
+24 Vdc +24 Vde 
+5 Vde +5 Vdc 


—5 Vde 


—5 Vde 


NOTE: 


All undesignated pins are to be left open. 


Figure 2-9. Interconnection method of Serial Paper 
Tape Reader 
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3.1 INTRODUCTION 


The 29B can be operated from the front panel keyboard or 
from remote control via a terminal or computer. 
Subsections 3.2 through 3.8 provide basic operation 
procedures from the front panel keyboard. Procedures for 
using the 296 from Remoie Coniroi are documented as 
follows: 


Computer Remote Control (CRC) Section 3.9.1 
System Remote Control (SRC) Section 3.9.2 
Terminal Remote Control (TRC) Appendix B 


The 29B obtains data for the basic operations from any of 
three sources: a master device, the serial port, or data 
entered manually from the programmer front panel 
keyboard. The basic operations of the 29B are: copy, 
verify, edit, and select functions. These are briefly 
described below and the step-by-step procedures are 
described in the following subsections. 


© Copy - moves data from source (device, RAM, or port) 
to a destination (device, RAM, or port). The specific 
copy operations are: 


Load RAM from serial port. Subsection 3.6.2. 
Program device with RAM data. Subsection 3.6.3. 
Qutput RAM data to port. Subsection 3.6.4. 

RAM to RAM block move. Subsection 3.6.5. 


Verify - compares data between a source and 
destination. The verify operations include: 


e Verify device data (comparing device data with RAM 
data) subsection 3.6.6. 

¢ Verify input data (comparing serial input data with 
RAM data) subsection 3.6.7. 


Edit - changes data at selected addresses within the 
programmer RAM. The edit operation is documented in 
subsection 3.7. 


Select Function - allows either the manipulating of RAM 
data or the changing of various operating parameters. 
These functions are listed and described in sub- 

section 3.8. 


These operations and their uses are further described in 
Introduction to Operation (see section 1). All front panel 
copy and verify operations are presented in subsection 3.6 


Load RAM with master device data. Subsection 3.6.1. 
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in a step-by-step key sequence format. Copy and verify 
operations foliow the source/destination method of data 
transfer and verification (see subsection 3.5}. Entries on the 
29B front panel keyboard are indicated by the 29B symbol 
and the key to be pressed. For example; instructions to 
press the RAM key on the 298 front panel keyboard would 
be illustrated as follows: 


E= [-] 


Section 3 consists of nine subsections. The title of each 
subsection and a brief explanation of each is listed below: 


3.1 INTRODUCTION: Lists the major items covered in this 
section. 


3.2 POWER-UP: Gives the procedures to apply power to 


the programmer. 


POWER DOWN: Gives the procedures to remove 
power from the programmer. 


Amr Arr A Lie 


MANUAL KEYBOARD OPERATIONS: Gives an 
explanation of the family/pinout code and explains the 
method of entering the code. Gives the procedures to 
insert and remove a device from the programmer pak 
or module sockets. 


SOURCE/DESTINATION METHOD CF SYNTAX 
(COPY AND VERIFY): Shows the syntax used when 
executing a copy or verify instruction. 


FRONT PANEL KEYBOARD DATA TRANSFER 
OPERATIONS: Gives the procedures to manually 
execute the copy and verify instructions from the 
programmer front panel keyboard. 


KEYBOARD EDIT OPERATIONS: Gives the procedures 
to execute edit instructions from the programmer front 
panel keyboard. 


SELECT KEY FUNCTIONS: Gives the procedures to 
execute select instructions from the programmer front 
panel keybaord. 


REMOTE OPERATIONS: Explains the two standard 
remote control systems used with the 29B Programmer 
and gives the command structure and operating 
procedures for each. 


Ga 
fa 


3.5 


3.6 


3.7 


3.8 


3.9 
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3.2 POWER-UP 


3.2.1 GENERAL OPERATION NOTES 


Keep the following items in mind while operating the 29B. 


Aborting an Operation. 


Most operations (except for a few select functions) can 
be aborted by pressing one of the four mode keys 
(COPY, VERIFY, SELECT, or EDIT). If an operation is 
in progress when one of these keys is pressed, the 29B 
momentarily displays the message: 


FUNCTION ABORT 


then assumes the mode selected and displays the 
message appropriate for the mode selected. 


Action Symbol. 


Copy, verify, and some select operations in progress are 
indicated by a rotating action symbol in the display as 
shown below. 


'V2n YA YA A Yan ae Pan Fn Ve m1 
ININCIN IN INCINCINOIN ANUEN | 


Changing an Address or Block Size. 


Some operations prompt for address or block size 
information by displaying a ‘““A" character followed by 
“ADDR” (in some cases ““ADDRESS”), or ‘SIZE’ on 
the front panel keyboard display. For example; a copy 
operation might prompt for a block size or beginning 
address. A specific block size, RAM address, device 
address, or serial data address offset can be entered 
from the programmer front panel keyboard with the 
numeric keys, or the default values can be entered by 
pressing the start key. The default states for the various 
address and block size parameters associated with 
device, RAM, and port-related operations are identified 
in subsection 3.5 (Source/Destination Method of 
Syntax). 


1/O Operation. 


When executing Input/Output related operations, be 
sure the correct operational parameters (i.e., baud rate, 
parity bits, and stop bits) are set (see subsection 2.5). 


3.2.2 POWER-UP PROCEDURE 


Use the following procedure to power-up the programmer: 


1. 


Install a programming Pak or module into the 
programmer if this has not already been done (see 
subsection 2.2). 
NOTE 

If a programming Pak or module is not 

installed in the programmer when power 

is turned on, the 29B will “beep” until a 

programming Pak is properly installed. 


CAUTION 
Be careful when installing the Pak to 
assure that the connector pins on the 
bottom of the Pak are not damaged. 


Check to make sure the sockets on the Pak are empty. 
If a device is in the socket, lift up the socket lever (see 
subsection 3.4.3) then gently lift the device out of the 
socket. See subsection 2.2 for Pak installation 
procedures. 


2. Plug the AC power cord into the rear of the 
programmer and into a power receptacle. 


3. Press the power switch at the back of the programmer 
to the “‘ON” position (see figure 3-1). 


POWER 
SWITCH 


PROGRAMMER POWER CORD 
BACK PANEL CONNECTOR 


Figure 3-1. Power Switch and Power Cord Locations 


When power is fully applied, the programmer automatically 
performs the self-test routine which initializes the 29B 
hardware and checks the scratch RAM, firmware and data 
RAM. While the self test routine is being performed the 
programmer will display: 


SEL TES? O 


NOTE 
The action symbol (["]) has a rotating 
hand which rotates several times to 
indicate the programmer is performing 
the self test. 


When the seif test is complete the programmer will display: 
| T TLM 
SELF PRST- GK 
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3.3 POWER DOWN 


CAUTION 
Do not turn the programmer power 
off while a device is in a socket; 
voltage transients may damage the 
device. 


Use the following procedure to remove power from the 
programmer: 


1. 
it is, wait until the operation is completed. 


. If a device is installed in a socket, remove it using the 
procedure described in subsection 3.4.3 before 
continuing. 


. Press the power switch to the OFF position (see 
figure 3-1). 


3.4 MANUAL KEYBOARD OPERATIONS 


The 29B performs the following basic front panel keyboard 


functions: 


® Copy Commands 


¢ Load RAM with master device data (sub- 

section 3.6.1). 

Load RAM from serial port (subsection 3.6.2). 
Program device with RAM data (subsection 3.6.3). 
Output RAM data to port (subsection 3.6.4). 

RAM to RAM block move (subsection 3.6.5). 


Verify Commands 
e Verify device data (subsection 3.6.6). 
¢ Verify RAM from serial port (subsection 3.6.7). 


® Edit Commands (see subsection 3.7) 


® Select Commands (see subsection 3.8) 


In addition to the basic front panel keyboard functions 


listed several operating functions may be selected using the 
keyboard edit (subsection 3.7) and select (subsection 3.8) 


functions. 


3.4.1 FAMILY AND PINOUT CODES 


Some Programming Paks use family and pinout codes to 
identify the programming algorithms used to program 


Insure the programmer is not executing an operation. If 


CAUTION 
Be sure you enter only those 
family/pinout codes published in the 
Pak manual(s). Invalid codes can 
cause Wnpredicabie 
device socket, which may damage 


alan ae: a 
results at the 


dauvina Aien 
Govicd. Aisd, 


the a valid family code 
and a valid pinout code can be 
combined to produce an invalid 
(illegal) combination. The correct 
family/pinout combination for a 
device can be determined by 
referring to the applicable pak 
manual(s). Any family and pinout 
combinations not contained in these 
manuals are considered illegal. 

Data I/O assumes no responsibility 
or liability for results produced by 
entry of illegal family/pinout code 


combinations. 


Paks that have the capability for use with more than one 


type of device will prompt the operator to enter or change 
the family/pinout code combination whenever device 
related operations are performed. If a family/pinout 
combination has never been entered, the 29B displays: 


fran SAA Trail fafa 
PIN ese LIN gdel 
NOTE 


lf this display appears, a family/pinout 
code must be entered before any device 
related operation can continue. 


The family and pinout codes are published in the manual 
for the Pak being used with the programmer. Use the Pak 
manual and the following procedure to determine the 


1. 


various programmable devices. The codes are listed in the 


programming Pak manual for those Paks that require a 
family/ pinout code entry. Once the codes have been 
entered in the 29B they remain in effect until they are 


changed for a new operation or power is removed from the 
g p 


programmer. 
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family and pinout codes for the device being programmed. 


Locate the manufacturer and part number stamped on 
the device. 


. Go to the family and pinout code table in the Pak 


manual and find the manufacturer’s name. 


. Go to the column entitled “Device Part Number’ and 


find the number corresponding to the number on the 
device. 


. Go to the column labeled ‘Family Code” and “Pinout 


Code” to find the code numbers corresponding to the 
device number for the manufacturer of the device. 


. Enter the Family and Pinout code you selected from the 


table when prompted by the programmer or terminal. 


If a family/pinout combination has been entered previously, 
that code combination appears as a hex code in the 29B 
display as follows: 


FAMsHH PIN HH 


Liu rr 


If the family/pinout code is correct for the device to be 
programmed, press the START key to continue. If it is 
not, press the applicable four keys on the hexadecimal 
keypad to enter the correct code. If an error is made while 
entering the family and pinout codes the copy or verify 
operation must be cancelled and restarted from the 
beginning. 


NOTE 
If the Pak or programming module is 
dedicated to one device, the 
family/pinout code is not required and 
the display prompt does not appear. 


3.4.2 DEVICE INSERTION 


After the applicable family and pinout codes have been 
entered, a device(s) can be inserted in the Pak device 
socket(s) or programming module socket adapter. The 
procedures presented here describe the insertion of a 
device in the 28-pin socket on a GangPak™, The basic 
insertion steps; however, apply to all devices and their 
socket receptacles. 


A good electrical connection between the device and the 
socket is essential. Use the following procedure to ensure 
the device is properly installed in the socket: 


1. Check to make sure the programmer is not executing an 
operation. If it is, wait until the operation is completed. 


2. Be sure the correct family and pinout code for the 
device is entered or available for entry when prompted. 


NOTE 
For some Paks such as the UniPak 2™ 
once the family/pinout has been entered 
an LED will light up to indicate the 
socket used for the device. 


3. Lift the lever on the side of the socket (see figure 3-2). 
The lever stays in the upright position. 


4. Gently set the device in the socket. Be sure that pin 1 
of the device is aligned with pin 1 of the socket as 
shown in Figure 3-2. If the socket has more contacts 
than the device has pins, insert the device so that the 
extra contacts are above the device; i.e., the bottom 
pins of the device must mate with the bottom pins of 
the socket. 


5. Push the lever down to lock the device in the socket. 
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3.4.3 DEVICE REMOVAL 


Use the following procedure to remove the device from the 
socket: 


1. Check to make sure the programmer is not executing an 
operation. If it is, wait until the operation is completed. 


2. Lift the lever on the side of the socket (see figure 3-2). 
The lever stays in the upright position. 


3. Lift the device out of the socket. 


SOCKET 
LEVER 
UNLOCKED 


SOCKET 
LEVER 
LOCKED 


PIN 1 


LED 
TYPICAL 


PIN 1 FOR 28-PIN 
DEVICE 


PIN 1 FOR 24-PIN DEVICE 


Figure 3-2. Device Installation (Multiuse Sockets) 
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3.5 SOURCE/DESTINATION METHOD OF The copy and verify commands are used in conjunction 


SYNTAX (COPY AND VERIFY) with the source/destination keys (DEVICE, RAM, and 
PORT). The operator initates the operation by choosing 
The 29B uses a source/destination method of syntax when either the COPY or VERIFY key, then specifing the source 
operations are executed with the COPY and VERIFY of the data (DEVICE, RAM, or PORT) and then the 
commands. This syntax is used for all copy and verify destination for the data fagain, either DEVICE, RAM, or 
operations commanded directly from the front panel PORT). By using table 3-1, you can determine the 
keyboard or indirectly via the System Remote Control. This operation you wish to execute based on the 
syntax is not used on either the Computer Remote Control source/destination concept. This table also provides you 
or the optional Terminal Remote Control. with the location of the operational procedure section, 
within this manual. To determine the source and 
3.5.1 SOURCE/DESTINATION DETERMINATION destination from the table go to the portion dealing with 
A COPY command operation directs the 29B to transfer the operation (copy or verify) to be performed and find the 
data from one medium to another. A VERIFY command box with the desired mode. Then read in the far left 
operation directs the 29B to verify data at one medium column the source required to perform the operation and 
against data at another to assure they are identical. read up to the top line for the destination required. 


Table 3-1. COPY and VERIFY Keyboard Operations 


COPY OPERATION 


DES TNSTION DEVICE RAM PORT 


SOURCE (blank device) (programmer data RAM) (peripheral) 


cee, VY LoaD mow DEVE 


RAM 
eo Ae See subsection 3.6.3 See subsection 3.6.5 See subsection 3.6.4 | 


iescioheeal Y cee 
| 


PROGRAM DEVICE BLOCK MOVE OUTPUT TO PORT 


VERIFY OPERATION 


2.cOENIGs RAM PORT 
(previously programmed 


device) (programmer data RAM) (peripheral) 


brooumne i Y a 
oi Yj Yy Uy Y 


UZZLZZZA Illegal Source/Destination Combination | 
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When the COPY command is used, data is moved from 
the source to the destination; for example, from the 
programmer data RAM to a blank device in the socket. At 
the completion of this operation the device will contain a 
copy of the data in the programmer RAM. The device is 
now “programmed.” 


When the VERIFY command is used, the programmer 
makes a byte-by-byte comparison of the data in RAM with 
the data in a programmed device or the data input from 
the serial port. In a verify operation, data in two mediums 
is compared, rather than transferred. 


3.5.2 GENERALIZED KEY SEQUENCE SYNTAX 


The generalized key sequence syntax for the COPY and 
VERIFY commands is: 


[function] [source] XXXX/YYYY [destination] ZZZZ 
[START] 


in the sequence format above function is either copy or 
verify, and both source and destination can be either RAM, 
device, or port. However, it should be noted that either the 
source or the destination must be RAM in any sequence. It 
is not possible to go directly between the device and the 
port in either direction. The data must always pass through 
RAM. The character strings XXXX, YYYY, and ZZZZ 
represent parameters associated with the 
source/destination keys. XXXX is the beginning source 
address. YYYY is the source block size and ZZZZ is the 
beginning destination address. Table 3-2 provides the 
usage, definition, and default values for these parameters. 
lf the default values are correct, it is not neccesary to enter 
them, just press [START] in the key sequence following 
the function (copy or verify). If a mistake is made while 
entering one of the parameters, press the [REVIEW] key to 
erase the entry for that parameter so the correct value can 
be re-entered. 


Table 3-2 Address Parameters 


Parameter'a) Default 
Key Source Dest. Name Value Definition 
Device XXXX ZZZZ Begin (Mb) First device address from which 
Device data is output or to which data 
Address is input. 
RAM XXXX ZZZZ Begin Otb) First data RAM address from 
RAM which data is output or to which 
Address data is input. 
Port XXXXic) ZZZZ\c) Address Output:!¢) The address offset is subtracted 
Offset 0 from all port addresses for input 
Input:(¢) and added to all RAM addresses 
First Address for output. 
Device, YYYY N/A Block (bite) The number of bytes to be 
RAM, or Size transferred. 
Port 


Notes: 


{a When defaults are in effect, ADDR is displayed for address parameters and SIZE is displayed for Block Size. 
(ob) To return to the default value, press REVIEW or enter 0. 


{c) Six or eight digits for 16-bit translation formats. 


(d) To return to the default condition enter FFFF (up to 8 characters). 
fe’ The default value is the device size in device-related operations. In port-related operations it is from the first RAM 


address specified to the end of RAM. 
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3.6 FRONT PANEL KEYBOARD DATA the keyboard. if an eniry is not made, the value 
TRANSFER OPERATIONS | defaults to the device siz 


u e 
place of “SIZE,” it is fro 


ize. If a hex value appears in 


a previously entered block 


3 


The following procedures describe how to perform data 
transfer operations from the 29B front panel keyboard. 


NOTE 


3.6.1 LOAD RAM WITH MASTER DEVICE DATA If a begin device address is specified then 


Use the following procedure to load the 29B RAM with the size must be specified also. The size 
data from a master device using the programmer front must be equal to or less than the device 
panel: . size minus the begin device address. 


| a. If the hex value that appears in place of “SIZE” is 
1. fy [=] correct, go to step 4. 
CN 


b. If it is incorrect, enter the correct hex value, then 
to select the mode. 


go to step 4. 
29B Displays — 
Es [el 
~ TNT 
LUPY DRIAR FROM 


to select the destination for the data. 


29B Displays 

2. Es ffee! 
a mr Nis s BA mT 
to select the source of the data. LU Be co RHI Nap ipt 


Z9B Dispiays The promot {A} preceding “ADDR” means that vou 
Ine promipe v/AV) prevcanig Auuen Maris tiat you 
can change the begin RAM address by entering the 

TE y ‘NN Fly UPR fe 5 Be Ze ee hex value with the keyboard. If an entry is not made, 
_ the value defaults to zero (0). if a nex value appears in 
place of “ADDR,” it is from a previously entered RAM 

The prompt (A) preceding “ADDR” in the display begin address. 

means that you can change the begin device address 

to any address within the range of device word limit 

by entering the hex value with the keyboard. If an 
entry is not made, the value defaults to zero (0). If a b. If it is incorrect, enter the correct hex value, then 

hex value appears in place of “ADDR,” it is from a go to step 5. 

previously entered begin address. 


a. If the hex value that appears in place of “ADDR” is 
correct, go to step 5. 


NOTE 
If the Pak or programming module 
installed does not require a family/pinout 
. If it is incorrect, enter the correct hex value. code combination the 29B automatically 
skips the next step. 


a. If the hex value that appears in place of “ADDR” is 
correct, go to step 3. 


ao 


a 


. If you do not wish to change the begin device 
address ‘or block size (step 3), go to step 4. 


wy 
— 
” MEE remeron EE 


29B Displays 


Tle FaMNMN 7 
JC ye HOUR ot t= TG 


29B Displays 


fr fe rAra FIT Ki CATA 

hinge LIN Ww 

L 

Enter the four digit hex family/ninout code 
combination for the device to be copied. The codes 
are listed in manual for the Pak or programming 
module installed. If a code combination other than 


The prompt (A) preceding “SIZE” means that you can 
change the block size by entering the hex value with 
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10. 


zeroes appears on the display, it is from a previously 
entered code combination. 


a. If the hex value that appears in place of the 
family/ pinout combination is correct, go to step 6. 


o 


. If it is incorrect, enter the correct family/ pinout 
code hex value, then go to step 6. 


NOTE 
If the Pak installed has more than one 
socket, the LED next to the correct 
socket will illuminate. 


Insert and lock the master device into the appropriate 
socket. (See subsection 3.4.2). 


oe 
> 
SN 


29B Displays 


LUALT 


~~ oa 
~ 


NOTE 
The amount of time the programmer will 
require to perform this operation will vary 
depending on the device size. The action 
symbol character rotates while the 
operation ts taking place. 


When the operation is complete, the following display 
signals the programmer’s readiness. If an error code is 
displayed, see appendix E. 


LOAD DONE 


JULI 


Me 


NOTE 
HHHH is the hex sumcheck of all the 
device data. If block limits are set the 
sumcheck (HHHH) will be calculated only 
for the block size. 


Remove the master device from the socket (see 
subsection 3.4.3). 


‘To repeat the load operation from another device with 


the same family and pinout codes return to step 7. 


3.6.2 LOAD RAM FROM SERIAL PORT 


Use the following procedure to load the 29B RAM from 
front panel keyboard with incoming serial port data: 


1. Set-up the serial port. Refer to section 2. 
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. Select the appropriate data translation format from 


appendix A and execute the format select function B3 
(see subsection 3.8). 


E> 


to select the mode. 
29B Displays 


TRY 


DATA PROM 


E> Fl 


to select the source of the data. 


29B Displays 


PORNADER/ SIZE TO 


The prompt (A) preceding “ADDR” in the display 
means that you can change the begin address offset to 
any address within the range of the data format by 
entering the hex value with the front panel keyboard. If 
an entry is not made, the value defaults to the first 
incoming address. If a hex value appears in place of 
“ADDR,” it is from a previously entered begin address. 
Enter FFFF (up to 8 characters) to reset the default. 


a. If the hex value that appears in place of “ADDR” is 
correct, go to step 5. 

. If it is incorrect, enter the correct hex value. 

. If you do not wish to change the begin device 
address or block size (step 5), go to step 6. 


iommeox 


a 


29B Displays 
POUR AGORASTZE TO 


The prompt (A) preceding “SIZE” means that you can 
change the block size by entering the hex value with the 
keyboard. If an entry is not made, the value defaults to 
zero (0). If a hex value appears in place of ‘‘SIZE,’’ it is 
from a previously entered biock size. 


a. If the hex value that appears in place of ‘SIZE’’ is 
correct, go to step 6. 


b. If it is incorrect, enter the correct hex vaue, then go 
to Rivals 6. | 


: 
r 


to seieci ine destination for the data. 


29B Displays 


The prompt (A) preceding “ADDR” means that you 
can change the begin RAM address by entering the hex 
value with the keyboard.’ If an entry is' not: made, the | 
value defaults to zero (0). If a hex value appears in 
place of “ADDR,” it is from a pISOuny entered RAM 
begin address. - 


a. If the hex value that appears in place of Ons i 
correct, go to step 7. 


b. If it is incorrect, enter the correct hex vane, then go 
to step 7. 


NOTE 


The amount of time the programmer will 
require to perform this operation will vary 
depending. on the data format, block size, 
and baud rate. The action symbot ["] 
character rotates while the operation is 
taking pee: 


8. When the operation is complete the following display 
signals the programmer's readiness. If an error code is 
displayed see appendix E. 


INPUT BONE | HHHH 


NOTE 
HHHH is the hex sumcheck of sal the 
received data. 


9. To repeat the load operation, return to step 7. 


3. 6 3 PROGRAM DEVICE WITH RAM DATA 


When programming a device, the system automatically 
performs illegal bit tests and blank checks at nominal Vcc 
to verify the ability of the PROM to accept programming 
before it begins the operation. Use the following procedure 
to program a blank device with data from RAM using the 


' programmer front panel keyboard: 


— 


to select the mode. 


29B Displays 


2 fs 


to select the source of the data. 
29B Displays 


RAMAADDR’ Size To 


The prompt (A) preceding “ADDR” in the display 
means that you can change the begin RAM address to 

- any address within the range of RAM word limit by 
entering the hex value with the keyboard. If an entry is 
not made, the value defaults to zero (0). If a hex value 
appears in place of “ADDR,” it is from a previously 
entered begin address. 


a. If the hex value that appears in place of “ADDR” is 
correct, go to step 3. 


b. If it is incorrect, enter the correct hex value. 


c. If you do not wish to change the begin device 
address or block size (step 3), go to step 4. 


——— 
= 
SN 


29B Displays 


RAM ADDR ASTZE TO 


The prompt (A) preceding “SIZE” means that you can 
change the biock size by entering the hex vaiue wiih 
the keyboard. If an entry is not made, the vaiue 
defaults to the device size. If a hex value appears in 
place of “SIZE,” it is from a previously entered block 
size. 
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a. If the hex value that appears in place of ‘‘SIZE”’ is 
correct, go to step 4. 


b. If it is incorrect, enter the correct hex value, then 
go to step 4. 


== 


to select the destination for the data. 


29B Displays 
CU RAM: DEV nAODR 


The prompt (A) preceding “ADDR” means that you 
can change the begin device address by entering the 
hex value with the keyboard. If an entry is not made, 
the value defaults to zero (0). If a hex value appears in 
place of “ADDR,” it is from a previously entered 
device begin address. 


a. If the hex value that appears in place of “ADDR” is 
correct, go to step 5. 


b. If it is incorrect, enter the correct hex value, then 
go to step 5. 


NOTE 
If the Pak or programming module 
installed does not require a family/pinout 
code combination the 29B automatically 
skips the next step. 


\ ooo 
Si) 
| aera eaascomaecee EEE, 


29B Displays 


FAM,GU PIN GU 


Enter the four digit hex family/pinout code 
combination for the device to be programmed. The 
codes are listed in the manual for the Pak or 
programming module installed. If a code combination 
other than zeroes appears on the display, it is from a 
previously entered family and pinout code. 


a. If the hex value that appears in place of the 
family/ pinout combination is correct, go to step 6. 


b. If it is incorrect enter the correct family/ pinout code 
hex value, then go to step 6. 


NOTE 
lf the Pak installed has more than one 
socket, the LED next to the correct 
socket will illuminate. 
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oo 
— 
{SN 


. Insert and lock the blank device into the appropriate 


socket. (See subsection 3.4.2). 


29B Displays 


FES EV ice ut 


If the device passes the blank check and illegal bit test 
the 29B automatically begins to program the device. 


29B Displays 
PROGRAM JEVWICe & 


When the device has been successfully programmed 
the 29B automatically verifies the programmed device. 


29B Displays 


VERIFY 


BEVICE OY 


NOTE 
The amount of time the programmer will 
require to perform these operations will 
vary depending on the device size, 
technology, and programming algorithm. 
The action symbol character ["] rotates while 
the operation is taking place. 


. When the operation is complete the following display 


signals the programmer's readiness. If an error code is 
displayed, see appendix E. 


29B Displays 
PRG DONE 4 HHHH 


NOTE 
The number (01) following PRG DONE 
(program done) is the sequence number. 
The sequence number increments by 17 
for each device programmed. HHHH is 
the hex sumcheck of all the device data. 
lf block is defined, the sumcheck 
(HHHH) will be calculated only for the 
block size. 


9. Remove the device from the socket. 


10. To program additional identical devices using the data 


stored in RAM return to step 6. 


3.6.4 OUTPUT TO SERIAL PORT 


Use the following front panel keyboard procedure to output 


data to the serial port: 
1. Set-up the serial port. Refer to section 2. 


2. Select the appropriate data translation format from 
appendix A and execute the format select function B3 
(see section 3.8). 


a 


to select the mode. 


29B Displays 


CORY 


DATA FROM 


os [+] 


CN 


to select the source of the data. 
29B Displays 


RAM ADDR’ SIZE To 


The prompt (A) preceding “ADDR” in the display 
means that you can change the begin RAM address to 
any address within the range of RAM word limit by 
entering the hex value with the keyboard. If an entry is 
not made, the value defaults to zero (0). If a hex value 
appears in place of “ADDR,” it is from a previously 
entered begin address. 


a. If the hex value that appears in place of ‘“‘ADDR’”’ is 
correct, go to step 5. 


b. If it is incorrect, enter the correct hex value. 


c. If you do not wish to change the begin device 
address or block size (step 5), go to step 6. 


EI 


29B Displays 


(NOM Onno cCT7e TN 
RAM AOURASIZE TG 
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The prompt (A) preceding “SIZE”’ means that you can 
change the biock size by entering the hex vaiue with the 
Keyboard. if an entry is not made, the value defaults to 
RAM size minus the begin RAM address. If a hex value 


appears in place of “SIZE,” it is from a previously 
entered biock size. 


a. if the nex value that appears in piace of ‘’SIZE”’ is 
correct, go to step 6. 


b. If it is incorrect, enter the correct hex value, then go 
to step 6. 


— 


to select the destination for the data. 
29B Displays 


LO RAM) POR vA 


The prompt (A) preceding “ADDR” means that you 
can change the address offset (see the glossary in 
appendix D) by entering the hex value with the 
keyboard. If an entry is not made, the value defaults to 
zero (0). If a hex value appears in place of ““ADDR,” it 
is from a previousiy entered address offset. 


a. If the hex value that appears in place of “ADDR’”’ is 
correct, go to step 7. 


b. If it is incorrect, enter the correct hex value, then go 
to step 7. 


ay 
Fs LJ 
LY 


29B Displays 


Miri 
ut PUT 


PORT 


C3 


NOTE 
The amount of time the programmer will 
require to perform this operation will vary 
depending on the data format, block size, 
and baud rate. The action symbol [7] 
character rotates while the operation is 
taking place. 


8. When the operation is complete the following display 29B Displays 
signals the programmer's readiness. If an error code is 
i i hA mn 7 ™T™| 
displayed, see appendix E. fort FT] Lf ‘x GI] Ze. FG 


The prompt (A) preceding “SIZE” means that you can 
change the block size by entering the hex value with the 


NOTE keyboard. An entry must be made or data can not be 
HHHH is the hex sumcheck of all the moved. If a hex value appears in place of “SIZE,” it is 
transmitted data. from a previously entered block size. 


a. If the hex value that appears in place of ‘’SIZE”’ is 
correct, go to step 4. 
b. If it is incorrect, enter the correct hex value, then go 


9. To repeat the output operation, return to step 7. 


3.6.5 BLOCK MOVE 


to step 4. 
A block move copies data in one block of RAM locations 
to another block of RAM locations, beginning at a defined 
address (see figure 3-3). Use the following front panel INSERT VIA BLOCK MOVE 
keyboard procedure to copy data from one location in 
RAM to another location in RAM: Moving Block “B” forward in 


memory causes block “C” to be 
lost. Data in block “X"’ remains 


\ ee . 
the same, but is only a fragment 
q; fy cory of block “B” and may be edited 
i or new data may be inserted. 


selects the mode. 
BEFORE AFTER 


X (FRAGMENT 
OF OLD ”B”) 


DELETE VIA BLOCK MOVE 


29B Displays 


CLURY DATA FR 


—— 


to select the source of the data. 


C3 


- i 


29B Displays 
RPAMARDDR/SIZE TY 


Moving Block “C” adjacent to 


The prompt (A) preceding “ADDR” in the display Block “A” causes deletion 
means that you can change the begin RAM address to of Block “B”. 

any address within the range of RAM word limit by 

entering the hex value with the keyboard. If an entry is BEFORE AFTER 


not made, the value defaults to zero (0). If a hex value 
appears in place of “ADDR,” it is from a previously 
entered begin address. 


a. If the hex value that appears in place of ‘““ADDR’”’ is 
correct, go to step 3. 


b. If it is incorrect, enter the correct hex value. 


- 


c. If you do not wish to change the begin device 
address or block size (step 3), go to step 4. X (FRAGMENT 


OF OLD “’C”’) 
\ oo / 
SN 


Figure 3-4. Block Move 
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The prompt (A) preceding ““ADDR” means that you 
can change the destination address by entering the hex 
value with the keyboard. If an entry is not made, the 
value defaults to zero (0). If a hex value appears in 
place of “ADDR,” it is from a previously entered 
destination address. 


a. If the hex value that appears in place of “ADDR” is 
correct, go to step 5. 


b. If it is incorrect, enter the correct hex value, then go 


to step 5. 
————— 
7 
Lo ' 
29B Displays 
17m sams 
BLULK MOVE gy 


NOTE 
The amount of time the programmer will 
require to perform this operation will vary 
depending on the block size. The action 
symbol character ["] rotates while the 
operation is taking place. 


6. When the operation is complete the following display 
signals the programmer's readiness. If an error code is 
displayed, see appendix E. 


BLULK MUVE DONE 


3.6.6 VERIFY RAM DATA AGAINST MASTER 
DEVICE DATA 


Use the following front panel keyboard procedure to verify 
that the data in the 29B RAM is the same as the data in 
the master device. 


a ee | | 
i eee a | ec | 


to select the mode. 
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298 Displays 


WERIFY DATA FROM) 


— 3 
to select the source of the data. 


29B Displays 


RAM WALD R/STZE TG 


The prompt (A) preceding “ADDR” in the display 
means that you can change the begin RAM address to 
any address within the range of the RAM word limit 
by entering the address hex value with the keyboard. 
If an entry is not made, the value defaults to zero (0). 
If a hex value appears in place of “ADDR,” it is from 
a previously entered begin address. 


a. If the hex value that appears in place of “SIZE” is 
correct, go to step 3. 


b. If it is incorrect, enter the correct hex value, then 
go to step 3. 


= 


29B Displays 


The prompt (A) preceding “SIZE” means that you can 
change the block size by entering the hex value with 
the keyboard. If an entry is not made, the value 
defaults to the device size. If a hex value appears in 
place of “SIZE,” it is from a previously entered block 
size. 


NOTE 
If a begin device address is specified, 
then the size must be specified also. The 
size must be equal to or less than the 
device size minus the begin device 
address. 


a. If the hex value that appears in place of ‘‘SIZE”’ is 
correct, go to step 4. 


b. If it is incorrect, enter the correct hex value, then 
go to step 4. 


= 


to select the destination for the data. 


29B Displays 


The prompt (A) preceding “ADDR” means that you 
can change the begin device address by entering the 
hex value with the keyboard. If an entry is not made, 
the value defaults to zero (0). If a hex value appears in 
place of “ADDR,” it is from a previously entered 
device begin address. 


a. If the hex value that appears in place of “ADDR” is 
correct, go to step 5. 


b. If it is incorrect, enter the correct hex value, then 
go to step 5. 


NOTE 
If the Pak or programming module 
installed does not require a family/pinout 
code combination, the 29B automatically 
skips the next step. 


E> Le] 


29B Displays 


FAM GO PIN UY 


Enter the four digit hex family/pinout code 
combination for the device to be verified. The codes 
are listed in the manual for the Pak module installed. If 
a code combination other than zeroes appears on the 
display, it is from a previously entered code 
combination. 


a. If the hex value that appears in place of the 
family/ pinout combination is correct, go to step 6. 


b. If it is incorrect, enter the correct family/ pinout 
code hex value, then go to step 6. 


NOTE 
If the Pak installed has more than one 
socket, the LED next to the correct 
socket will illuminate. 


. Insert and lock the device into the appropriate socket. 
(See subsection 3.4.2). 
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\ 
a hee 
{SS 


29B Displays: 
mM 


WE FOL FV Lu 


The 29B will perform a two-pass verify. 


New Tere 
ves al 


NOTE 
The amount of time the programmer will 
require to perform this operation will vary 
depending on the device size. The action 
symbol line rotates 360 degrees while the 
operation is taking place. 


8. When the operation is complete the following display 


9. 
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signals the programmer's readiness. 
VE DEV BONE HHHH 


NOTE 
HHHH is the hex sumcheck of all the 
device data. If block size is defined the 
sumcheck (HHHH) will be calculated only 
for the biock size. 


If the device does not verify the following error 
message format will appear: 


WN HHH THE RHH 


NOTE 
The N in VN is the number of the verify 
pass, either 71 or 2. HHHH is the address 
where the verify error was found. DHH is 
the device hex data and RHH is the RAM 
hex data. 


If a verify error is displayed, press the START key to 
resume verifying at the next address. Verification will 
resume until all addresses have been verified or 
another error is found. Press the START key as 
many times as is required to locate all of the 
addresses where there is a verify error. 


NOTE 
The LogicPak™ verify error message is 
different. Refer to the LogicPak™ manual 
for the error message format. 


10. Remove the device from the socket. 


11. To repeat the verify operation, return to step 6. 


3.6.7 VERIFY RAM FROM SERIAL PORT 


Use the following front panel keyboard procedure to verify 


it) 


. If the hex value that appears in place of ’’SIZE”’ is 
correct, go to step 6. 


that the RAM data is the same as the incoming serial port b. If it is incorrect, enter the correct hex value, then go 
data: to step 6. 
1. Set-up the seriai port Refer to section 2. 


i, the seriai port. Refer to sectia — 
2. Select the appropriate data transiation format from 6. [— <= { EORT | 


appendix A and execute the format select function B3 


(see subsection 3.8). to select the destination for the data. 
: [—_—~ 29B Displays 
17 Cytyaa \ m7 TN 
to select the mode. y t= AM POR) AOR 
298 Displays 


The prompt (A) preceding ““ADDR”’ means that you 

fm Tirov His T rm c syaly can change the address offset by entering the hex value 
Virot Ari jit with the keyboard. If an entry is not made, the value 

defaults to zero (0). If a hex value appears in place of 

“ADDR,” it is from a previously entered address offset. 


mi ee ea D sa a. If the hex value that appears in place of ““ADDR’”’ is 
correct, go to step 7. 


vc 
vu 


to select the source of the data. 
b. If it is incorrect, enter the correct hex value, then go 


29B Displays to step 7. 

Mm ONNDW-CTF m 
FeRM FAT Dre, S34LE ful 7 Pf ser 
The prompt (A) preceding “ADDR” in the display ze 
means that you can change the begin RAM address to 298 Displays 
any address within the range of RAM word limit by 

I 

entering the address hex value with the keyboard. If an ve Fe IF ‘ f3 Fe T He 


entry is not made, the value defaults to the first 
incoming address. If a hex value appears in place of 


“ADDR,” it is from a previously entered begin address. NOTE 
The amount of time the programmer will 


require to perform this operation will vary 
depending on the data format, block size, 
b. If it is incorrect, enter the correct hex value. and baud rate. The action symbol 
character rotates while the operation Is 
taking place. 


a. If the hex value that appears in place of “ADDR” is 
correct, go to step 5. 


c. If you do not wish to change the begin device 
address or block size (step 5), go to step 6. 


— 8. When the operation is complete, the following display 
5: fy Tm | signals the programmer's readiness. If an error code is 
Loo NN 


displayed, see appendix E. 


29B Displays VE POR TONE HHHH 


RAM ADTRASIZE TO 
NOTE 
HHHH is the hex sumcheck of all the 
device data. If block limits are set the 
sumcheck (HHHH) will be calculated oniy 


for the block size. 


The prompt (A ) preceding “SIZE’’ means that you can 
change the biock size by entering the hex value with the 
keyboard. if an entry is not made, the value defaults to 
RAM size minus the begin RAM address. If a hex value 
appears in place of “SIZE,” it is from a previously 


; . To repeat the veri eration, return to step 7. 
entered block size. 9. To repe fy op e step 7 
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3.7 KEYBOARD EDIT OPERATIONS 


The EDIT key allows the operator to change the stored 
data at a specified RAM address. The data may be 
presented in either binary, octal, or hexadecimal, as 
determined by a select code (F5, F6, or F7 respectively). 
The programmer automatically comes up in hexadecimal, 
which is the default condition. However, if either octal or 
binary is desired, it may be selected using the applicable 
select code. 


If edit addresses are outside the range of the device 
addresses two asterisks (**) are displayed for the device 
data. 


Since the display varies when an edit operation is 
performed in the three numbering systems an example of 
each is given below. 


NOTE 
The symbols H, Q, or B are used in 
subsections 3.7.1 through 3.7.3 to denote 
hexadecimal, octal, or binary numeric 
characters. Therefore, an “H” symbol on 
a key means the operator can press any 
key on the numeric key pad. A ““B” 
symbol implies only @ or 7 can be 
pressed, since binary values are 
composed of only Q's and 1's. 


3.7.1 HEXADECIMAL BASE 


Use the following procedure to edit data in a RAM address 


when the hexadecimal base has been selected, either by 
select code F7 or default: 


= 


to select the operating mode. 


29B Displays 


EIT RUDRA HHHH 


The prompt (A) after “ADDR” in the display means 
that you can change the RAM address to be edited by 


entering any hex address within the range of the RAM. 


The “‘HHHH” in the display represents the last hex 
address edited (power-up default is 0000). 


a. If the hex value address displayed is correct go to 
step 3. 


b. If it is not correct go to step 2. 
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hex address to be edited. 


29B Displays 


ERIT ALOR, HHH 


entered hex address. 


ro oad 


29B Displays 


HHHH HHA RHH 


The “HHHH” in the display represents the hex address 
in RAM to be edited. The device data is represented by 
the “‘DHH” symbols; The “D’’ representing the device 
and the “HH” the hex data in the device at the address 
defined. The RAM data to be edited is represented by 
the symbols ‘““A RHH.” The prompt symbol “A” to 
show that this data can be edited, the ‘’R” to show it is 
in RAM, and ‘HH’ to show the hex value of the data 
presently entered in that RAM address. 


NOTE 
When the 29B initially powers up, device 
data is undefined since the device 
family/pinout code is also undefined. 
Therefore; under these conditions the 
edit command will show “D**”. After a 
device type has been defined (usually as 
the result of a copy or verify device 
operation) device data can be compared 
with RAM data; however, device data is 
only shown for the block of data 
beginning at the begin RAM address and 
with a length equal to the device size 
minus the begin device address. 


E& OG 


hex data to be entered in RAM address. 


29B Displays 


HHHH HHA RHH 


new data is displayed following the A R. 


o1 


The procedure may be continued in any of the following 
ways: 
-® Press START to increment (+1) the address to edit 


the next higher RAM location and then resume at 
either step 4 or 5, as applicable. 


e Press REVIEW to decrement (— 1) the address to edit 
the next lower RAM location and then resume at 
either step 4 or 5, as applicable. 


e Press EDIT to select another RAM address for editing 
and then resume at either step 2 or 3, as applicable. 


6. Press any other function (blue) key (COPY, VERIFY, 
SELECT) to exit from the EDIT mode of operations. 
3.7.2 OCTAL BASE 


Use the following procedure to edit data in a RAM address 
when the octal base has been selected (select code F6): 


= 


to select the operating mode. 


29B Displays 
EHIT AOR. HHAH 


The prompt (A) following “ADDR” in the display 
means that you can change the RAM address to be 
edited by entering any hex address within the range of 
the RAM. The “HHHH” in the display represents the 
last hex address edited (power-up default is 0000). 


is 


a. If the hex value address displayed is correct go to 
step 3. 


b. If it is not correct go to step 2. 5. 


OOO 10 


hex address to be edited. 


29B Displays 


ERIT AUR. HHH 


entered hex address. 


=> 
Ss 
"Oa carvers, 


HHHH fiviviy vos 
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Ss 1 2 I 


The “HHHH" in the dispiay represents the hex address 
in RAM to be edited. The defined device data is 
represented by the ““DQQQ” symbols; The “D’” 
representing the device and the “OOO” the octai data in 
the device at the address defined. The RAM data to be 
edited is represented by the symbols “A ROQCQ.” The 
prompt symbol! ‘A’ to show which data can be edited, 
the “‘R” to show it is in RAM, and “‘QQQ” to show the 
octal value of the data presently residing in that RAM 


address. 


NOTE 
When the 29B initially powers up, device 
data is undefined since the device 
family/pinout code is also undefined. 
Therefore; under these conditions the 
edit command will show “D***.” After a 
device type has been defined (usually as 
the result of a copy or verify device 
operation) device data can be compared 
with RAM data; however, device data is 
only shown for the block of data 
beginning at the begin RAM address and 
with a length equal to the device size 
minus the begin device address. 


i] 
o 


b—Z\J 
octal data to be entered in RAM address. 


29B Displays: 


HHH Divi nROO 


new data is displayed following the A R. 


The procedure may be continued in any of the following 
ways: 


e Press START to increment (+1) the address to edit 
the next higher RAM location and then resume at 
either step 4 or 5, as applicable. 


Press REVIEW to decrement (—1) the address to edit 
the next lower RAM location and then resume at 
either step 4 or 5, as applicable. 


Press EDIT to select another RAM address for editing 
and then resume at either step 2 or 3, as applicable. 


. Press any other function (blue) key (COPY, VERIFY, 


SELECT) to exit from the EDIT mode of operations. 


3.7.3 BINARY BASE NOTE 
When the 298 initially powers up, device 
data is undefined since the device 
family/pinout code is also undefined. 
oo Therefore; under these conditions the 
———s [=] edit command will show “D**,” After a 
1. device type has been defined (usually as 
the result of a copy or verify device 
operation) device data can be compared 
with RAM data; however, device data is 
only shown for the block of data 
beginning at the begin RAM address and 
fe HH i i Fy TER vA I Hi H with a length equal to the device size, 
minus the begin device address. 


The prompt (A) following ‘‘ADDR”’ in the display ) aac, (0k) ames ( a | ai Cl 
means that you can change the RAM address to be 4. f——" 
edited by entering any hex address within the range of Ieee 
the RAM. The ““HHHH"” in the display represents the 


last hex address edited (power-up default is 0000). [e) 
a. If the hex value address displayed is correct, go to AN Re AREA EEN OLR A 


Use the following procedure to edit data in a RAM address 
when the binary base has been selected (select code F5): 


to select the operating mode. 


29B Displays 


step 3. binary data to be entered in RAM address. 
b. If it is not correct, go to step 2. 
29B Displays: 
LaLatth | 7” 
2s EG HHHH HH, BBBBBBOS 
haxcaddiace to be saned: new data is displayed following the “A”. 
29B Displays: 5. The procedure may be continued in any of the following 
TTT 77N | Sie 
es af 
at i! HUDF a rH aL i e Press START to increment (+1) the address to edit 
entered hex address. the next higher RAM location and then resume at 


either step 4 or 5, as applicable. 


— = 
3. poy Te) ¢ Press REVIEW to decrement (-— 1) the address to edit 
SS the next lower RAM location and then resume at 
either step 4 or 5, as applicable. 


29B Displays e Press EDIT to select another RAM address for editing 
and then resume at either step 2 or 3, as applicable. 


HHrr rir iN BRERBRRBE 6. Press any other function (blue) key (COPY, VERIFY, 


SELECT) to exit from the EDIT mode of operations. 


The “HHHH” in the display represents the hex address 
in RAM to be edited. The defined device data is 
represented by the “HH” symbols; representing the hex 
data in the device at the address defined. The RAM 
data to be edited is represented by the symbols 

“A BBBBBBBB.” The prompt symbol “A” to show 
which data can be edited and ‘‘BBBBBBBB” to show 
the binary value of the data presently entered in that 
RAM address. 
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3.8 SELECT KEY FUNCTIONS 


The SELECT key allows the operator to perform additional 
operations, called select functions, that are used for: 


e RAM data manipulations 
e Utility and inquiry commands 


© Serial |[/O commands 


3.8.1 ACCESSING SELECT FUNCTIONS 


The select functions may be accessed by either direct 
entry, stepping, or scrolling. 


For direct entry, press SELECT. The 29B will display 
“SELECT CODE.” Enter the hex code for the desired 
function or data translation format and then press START. 
(Some functions, e.g. those to enter terminal remote 
control, require the START key to be pressed twice.) The 
display will prompt any additional entries required, or 
indicate an invalid entry. 


To access the select functions by stepping, depress the 
SELECT key repeatedly until the function desired is 
displayed. Then press the START key to initiate the 
operation. Press the REVIEW key to step backwards 
through the select functions. The functions are displayed in 
hexadecimal order. 


To access the select functions by scrolling, depress 
SELECT ana then 
displayed in turn. When the desired function is displayed 
press any key to stop the scrolling. To back up, press 
REVIEW. Once ihe desired select function is displayed, 


initiate the operation by pressing START. 


« . . 
TA im MR AaANtaril: 


TART Tank f..nn¢ 
IAAL. Cath TUACUGN iS MOMEeNtariy 


The programmer signals that the operation is complete by 
displaying two asterisks (**) in the last two display 
positions. 


3.8.2 EXTENDED SELECT FUNCTIONS 


Some Paks feature specific operations, resident in their Pak 
software, called extended select functions. These functions 
generally are of a utility nature and are documented in their 
respective Pak manuals. Use the applicable Pak manual for 
specific step-by-step instructions. 
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3.8.3 DESCRIPTIONS AND KEY SEQUENCES 


Following are the select functions, their descriptions, and 
key sequences. The key sequences are for direct entry. 
When stepping or scroiiing simpiy skip the steps preceding 
the display of the desired select function and enter the 


a fe ee ae 


operation ‘at that point (normaily 


ae pe 


a ft ee oe lls ee I 
siep 3 of the procedure). 


The command descriptions and key sequences are arranged 


in hexadecimal order within the three major headings, i.e., 
RAM data manipulation (3.8.4), utility and inquiry (3.8.5), 
and seriai 1/O (3.8.6). Table 3-3 is a summary of the select 
commands, in hexadecimal order. 


Table 3-3. Select Commands 


TITLE 


COMMAND GROUP 


01-99 Format Codes Format Codes 
Al Swap Nibbles RAM Data Manipulation 
A2 Fill RAM RAM Data Manipulation 
A3 Invert RAM RAM Data Manipulation 
A4 Clear All RAM RAM Data Manipulation 
AS Split RAM RAM Data Manipulation 
A6 Shuffle RAM RAM Data Manipulation 
BO Device Size Utility and Inquiry 
SumCheck RAM Utility and Inquiry 
System Config Utility and Inquiry 
Format Number Utility and Inquiry 
| Nonblank Fail Utility and Inquiry 
Display Test Utility and Inquiry 
Calibration Utility and Inquiry 
Leader Output Serial !/O 
Size Record Serial 1/0 
Null Count Serial I/O 


Program Count 
Remote Mode CRC 


Utility and Inquiry 
Utility and Inquiry 


PESRISGARSANVSASRYLBSEBRES 


29B TRC Utility and Inquiry 
Lock Data On Utility and Inquiry 
Nibble Mode Utility and Inquiry 
Binary Base Utility and Inquiry 
Octal Base Utility and Inquiry 
Hex Base Utility and Inquiry 
Byte/Nib Mode Utility and Inquiry 
Timeout Off Serial I/O 
Char Output Serial 1/O 

FB Enable Port Serial 1/O 

FC Remote On Off Serial 1/0 
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3.8.4 RAM DATA MANIPULATION COMMANDS: 


A1 SWAP NIBBLES Command 
Use the following procedure to exchange high- and low-order 
nibbles of every byte: 


= 


to select the select function. 


GEL “Lt LUE ‘N 


The prompt (A) following “SELECT CODE” on the 
display means that the two character hex select function 
code must be entered before the procedure can continue. 


to select the swap nibbles function. 


29B Displays 


SELECT COTE  »R% 


Sr, 
| 
: 
Ps) 
4 
L——\ 


to exchange high and low order nibbles of every byte. 


29B Displays 


GWAR NI BALES di 
Action symbol rotates. 
Gwe? NIBBLES Kx 


Swap nibble function is complete. 


A2 FILL RAM Command 


Use the following procedure to fill RAM from the last EDIT 
address to the end of RAM with variable hex data. The 
default data value is 00. If select function F4 has been 
specified, or if a 4-bit device is selected, it will fill only the 
lower order nibbles of RAM; otherwise it will default to the 
word width of the selected device. 


—— 


to select the select function. 


29B Displays 
fr rer Cane 
CLet! LUTE on 


The prompt (A) following “SELECT CODE” on the 
display means that the two character hex select function 
code must be entered before the procedure can continue. 


2s EE) 
CN 
to select the fill RAM function. 


29B Displays 


SELECT CODE 


— = 
Fs EI 


CaN 


ne 


29B Displays 


[=] 
[=] 


Hex data to be placed in RAM. 


29B Displays 
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== 
oy ee || 
SS SN 


to write the entered hex data in RAM. 


29B Displays 
[TI 3 RA m 
PELL PEM 1 HH Lj 
Action symbol rotates. 
Tit 
PILL PRAM KK 


Fill RAM function is complete. 


A3 INVERT RAM Command 


Use the following procedure to perform the ones complement 
of 4 or 8 bits of each word, as determined by the word size 


in effect: 


to select the select function. 


29B Displays 
Tri cer Fron 
JOLOwI! be N 


The prompi (A) following “SELECT CODE” on the 
display means that the two character hex select function 


code must be entered before the procedure can continue. 


to select the invert RAM function. 


29B Displays 


Tr 


CELEL! LUL ites rf 


ww 
—— 
CS 


298 Dispiays 


INVERT Foran FAs 


a | 
4S omer 


to perform a ones complement on data stored in RAM. 
29B Displays 


INVERT Foran "7 


Action symbol rotates. 
‘ERT RAM KK 


Invert RAM function is complete. 


A4 CLEAR ALL RAM Command 


Use the following procedure to clear all RAM to zeros: 


— 


to select the select function. 


29B Displays 


The prompt (A) following “SELECT CODE” on the 
display means that the two character hex select function 
code must be entered before the procedure can 
continue. 


—< 


to select the clear all RAM function. 


29B Displays 


recrr Trane 
GELEL] Lege rH 


> 
fs EI 
Le _S 


29B Displays 


LLEAR ALL RAM AY 
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= 
3 
LS 


to clear all RAM to zeros. 
29B Displays 
LLEHR ALL RAHM 
action symbol rotates. 
CLEAR ALL RAM &X 


clear all RAM function is complete. 


A5 SPLIT RAM Command 


Use the following procedure to split odd- and even- 
addressed bytes in RAM about a center point, dividing 
them into two adjacent blocks occupying the same original 
amount of RAM. The center point must be a power of two 
between 0 and the RAM midpoint. The default center point 
is the RAM total midpoint. 


— 


to select the select function. 


29B Displays 
~I corr Froane\e 
SELEL | LUE IN 


The prompt (A) following ‘SELECT CODE” on the 
display means that the two character hex select function 
code must be entered before the procedure can 
continue. 


2 old 


to select the split RAM function. 


29B Displays 


Ewen? COTE. Ans 
\e-—. oo 
= 
eee 


29B Displays 


SPLIT RAM 


wHHHH 


E> BAY 


sets the hex midpoint. (Step can be skipped if the 
total RAM midpoint is correct.) 


29B Displays 


SPLIT RAM 


to split the RAM around the designated midpoint. 


29B Displays 

SPLIT RAM i 
action symbol rotates. 

SPLIT RAHM KK 


split RAM function is complete. 


A6 SHUFFLE RAM Command 


Use the following procedure to shuffle the block of RAM 
addresses immediately above the center point with the 
block below, placing the lower-block bytes at even- 
numbered addresses starting with 0 and the upper-block 
addresses at odd-numbered addresses starting with 1. The 
center point must be a power of two between 0 and the 
RAM midpoint. The default center point is the total RAM 
midpoint. 


— 


to select the select function. 


29B Displays 
1 err Cone | 
Seiler LW de ‘N 


The prompt (A) following ‘‘“SELECT CODE” on the 
display means that the two character hex select function 
code must be entered before the procedure can 
continue. 
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2s Pallet 
tL——_Jj pA KA 


to select the shuffle RAM function. 


29B Displays 


SELECT COGE  nAb 


oe 
= 
CS 


29B Displays 


to set the hex midpoint. (Step can be skipped if 


the total RAM midpoint is correct.) 
29B Displays 


FELE RAM 


a aD a 
ri 


— 
= 
SS 


HHH 


[= 
(= 
[ 


3.8.5 UTILITY AND INQUIRY COMMANDS 


BO DEVICE SIZE Command 


Use the following procedure to display the device size and 
word width currently entered. The default values vary with 
the Pak or programming module in use. 


— [=f 


to select the select function. 


29B Displays 


The prompt ( A) following “SELECT CODE” on the 
display means that the two character hex seiect function 
code must be entered before the procedure can 
continue. 


7 a ele] 


to select the device size function. 


29B Displays 


Mo 
to shuffle the RAM around the designated midpoint. 3. a 
Lo '\ 


29B Displays 


SHUFFLE RAM at 


Action symbol rotates. 


GHUFFLE RAM kx 


Shuffle RAM function is complete. 


to display in hex the current or default device size 
and word size. 


29B Displays 


HHHH represents the hex value of the device size 
and H represents the hex value of the word size. 
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B1 SUMCHECK RAM Command 


Use the following procedure to display the total RAM 
sumcheck: 


E> el 


to select the select function. 


29B Displays 


SELECT 


MTN 


LL) iN 


The prompt (A) following ‘““SELECT CODE” on the 
display means that the two character hex select function 


code must be entered before the procedure can continue. 


cs io 


to select the RAM sumcheck function. 


co 


29B Displays 


U UE 


— ay 
SS 
LS 


to display the RAM sumcheck in hex. 


v4 


= 
GELELT C 


29B Displays 
LSUMCHEDLK HHHH XK 
HHHH represents the hex value of the total RAM 


sumcheck. 


B2 SYSTEM CONFIG Command 


Use the following procedure to display the four character 
system configuration code: 


= 


to select the select function. 
29B Displays 


SELECT 


‘N 
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The prompt (A) following ‘SELECT CODE” on the 
display means that the two character hex select function 
code must be entered before the procedure can 
continue. 


to select the system configuration function. 


29B Displays 

SELELT CUBE vB 
—== 

= 

29B Displays 

HHH HK 2S 8 an 


to display the four character system configuration 
code (HHHH), RAM size (HHK), Model (29B), and 
version number (VHH). 


B3 FORMAT NUMBER Command 


The 1/0 format can be selected in either of three ways. If 
the desired format number is known the select mode can 
be accessed and the code entered directly. The indirect 
methods allows the operator to display the current or 
default entry and then change the entry by either stepping 
through the formats, or entering the format code. Refer to 
Appendix A to determine which instrument control code 
and format code is desired. 


Use the following procedure to enter a new data translation 
format number directly: 


= 


to select the select function. 


29B Displays 
ee ee Crone 
ia TLE! Lue N 


The prompt (A) following “SELECT CODE” on the 
display means that the two character hex select function 
code must be entered before the procedure can 
continue. 
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2. $< oMmd 3, zee (| 


te select the format number; where the first 


number is the optionai instrument control code 29B Displays 
idefauit is zero if not entered) and the second and Sa ee 
j WANA NA AA NA NA NA NIA NA A Nd IY I I 
third numbers are the format code. FN EN EN AN AN AS AS AN AN ANAS AN OUNCES K 4N 
29B Displays to display the mnemonic for the current (or default) 
format number. 
“—MOranr am CANIN ERG i ic I i 
Fe LJ fd Mrat tig NUSINENEN If the displayed format mnemonic is the desired format 


go to step 6. If it is not, go to step 4. 


ic ‘Es [lly od 


to select the format number; where the first 
number is the optional instrument control code 
(default is zero if not entered) and the second and 


WRVERVARVARURURURURURURUR TRUE TRUE T third numbers are the format code. 
NANANNANINNIVAA AA AAAS 


29B Displays 


to display the mnemonic for the selected format. 29B Displays 
—— 
af— coomoT Mm TAN IBINI 
START CYAN GT j INES INGDITNENEN 
Lo _N 
29B Displays 


5. ee [| START | 
L_____ bj 


the format number selection is complete. 
29B Displays 
Use the following procedure to display and change the 


4 . WANA NA AZ AA AA NA AA NA NA AS NA AS A A NA 
current data translation format number: AINA IND ANAIVAIVAN INN AN AABN 


to display the mnemonic for the selected format. 
—-S sinew 
| ret 
to select the select function. 6. [-—— iia 
{SY 
29B Displays 


29B Displays 


Th 
YC ‘N = : 
FORMAT NO NNN KK 


the format number selection is complete. 
The prompt ( A) following ““SELECT CODE” on the 
display means that the two character hex select function 
code must be entered before the procedure can 
continue. 


to select the format number function. 


Use the following procedure to step through the display to 
change the data translation format number: 


29B Displays 


Ceierr ronc. SELELT tu a 
SELEL! CORE »n8S 
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The prompt (A) following “SELECT CODE” on the B4 NON BLANK FAIL Command 
display means that the two character hex select function 
code must be entered before the procedure can 
continue. 


Use the following procedure to automatically fail non-blank 
devices when the 29B is equipped with the optional 
handler. If the optional handler is not connected the 
command has no effect on the system. When power is 

oo eon . . . 

initially applied to the 29B with the optional handler 

2. installed the default condition is to attempt to program any 

Coe 2 

; non-blank devices detected. 
to select the format number function. 


29B Displays +: [os 


Crt cor crate a j 
pe | ae f- Li Lbs ae: K B34 to select the select function. 
29B Displays 
——— 
= 
Lo _S 
29B Displays The prompt (A) following “SELECT CODE” on the 


display means that the two character hex select function 
WAS NANA NA NA NA AA NA NAY NA A A 
IN IN ININ IN IN EN AN OIN IN IN OIN IN ANNAN code must be entered before the procedure can 


to display the mnemonic for the current (or default) cOnenue: 
format number. 


2S [eh] 
If the displayed format mnemonic is the desired format pA 


go to step 5. If it is not use go to step 4. to select the non blank fail function. 


(fT! Tr mnie L 
D 
Press and release until the desired format appears SE L [- Lb Lue NN Hi | 


on the keyboard display. Press REVIEW to step the 
display backwards. 


oo / 
29B Displays 3. [ 
C!S 


WW NANA VANE NA AAAS NAN AS RUA 
INCEN IN OEN EN OPN EN EN EN OPN EN EN ODN Ne 


— 

— 
Lo _N 

29B Displays 4. {[——=y 


pric nA iF him? RINNE 4 uv to place the non-blank fail function in effect if the 
i ENE NEN optional handler is connected. 
the format number selection is complete. 


i 
: 29B Displays 


NONBLANK FALL BY 
——— 
START I 


CS 


29B Displays 
Ti Caan TI 4 
MONELANK FALL Kx 
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BS DISPLAY TEST Command 


Use the following procedure to perform the display test (all 
14 segments of the 16 indicators illuminate for 
approximately four seconds): 


SELECT 


29B Displays 
rei ocrorr Front 
pi | seg Da eg ee Pe eae OS N 


The prompt (A) following “SELECT CODE” on the 
display means that the two character hex select function 
code must be entered before the procedure can 
continue. 


—s0]0 


to select the display test function. 


29B Displays 
Cm ecror cman 
JCLELI Lu yo vB 
—= 
ss Le] 
Le NSN 
29B Displays 
ATC ! vw oT 
ULSPLAY FEST RY 
oo / 
ESS [Le] 
Lo eeeN 


to illuminate all display segments for 4 seconds. 
29B Displays 


G9 E99 E99 EO EN EO EO 0 ED 


for 4 seconds. 


29B Displays 
[ii 3r-or bc 34 KK | 
after 4 seconds 
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Ci CALIBRATION Command 


The calibration command response differs between 
programming Paks and programming modules. In addition 
some Paks will prompt for additional features. 


to select the select function. 


29B Displays 
“| EOCTrF Cone 
SELEL | LOE 


The prompt (A) following “SELECT CODE” on the 
display means that the two character hex select function 
code must be entered before the procedure can 


to select the calibration function. 


29B Displays 
LOOT Tone "A 
SELELT COTE nit 
— 
— 
Lee WN 
29B Displays 
Tm A 
LAL GTEP rO4 


See section 4 and the programming pak or programming 
module manual for the calibration procedures. 
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FO PROGRAM COUNT Command F1 REMOTE MODE Command 


Use the following procedure to display the number of Use the following procedure to select the Computer 
devices programmed since the last power-up or reset: Remote Control (CRC) mode. 
Pm —, Ce NN 
to select the select function. to select the select function. 
29B Displays 29B Displays 
P= = Ti Cri err crane 
LEE T CORE ‘N JOUCL I LUE iN 
The prompt (A) following “SELECT CODE” on the The prompt (A) following “SELECT CODE” on the — 
display means that the two character hex select function display means that the two character hex select function 
code must be entered before the procedure can code must be entered before the procedure can 
continue. continue. 
a 
2s [el fe] 2S EC] 
' erasers 
to select the program count function. to select the computer remote control function. 
29B Displays 29B Displays 
Cri acrr Fane a, =~ CrTr CTmMnNnce A 
SELELT CODE anki SELECT COGE wf 4 
aoe Ne 
ces aa = Ll 
YS {SN 
to display the decimal contents of the program 
counter. 29B Displays 
: T on 
29B Displays REM iC MODE f- 4 


PROGRAM COUNT NN 


rr 
ee ed 
To simply observe the contents of the program counter 


stop here. To reset the program counter to 00 continue to place the programmer in Computer Remote Control. 
to step 4. 
29B Displays 


\o 
Ls | ] REMOTE MODE 6 


Le MN 
Refer to subsection 3.9.1 for further information on 


to reset the program counter. 
pig Computer Remote Control. 


29B Displays 


PRUDRAM LOUNT Kx 
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F2 298 TRC [Termina! Remote Contral) Command 


Use the following procedure to select the optional Terminal 
Remote Control (TRC): 


to select the select function. 


29B Displays 
icrr ran 
GEL 7 LUE IN 


The prompt (A) following ‘“SELECT CODE” on the 
display means that the two character hex select function 
code must be entered before the procedure can 
continue. 


2s EI] 


to select the terminal remote contro! function. 


29B Displays 
~T TF CFmne rs 
ISEGELT LOE APs 
een 
Fs Ee] 
29B Displays 


CGR TRO be 


to place the programmer in the optional Terminal 
Remote Control mode. 


29B Displays 
THOS 
eGR TRO gj 
Refer to appendix B for further information on Terminal! 
Remote Control. 


F3 LOCK DATA ON Command 


When the data Lock On function is selected the data in 
RAM is protected because the keys used to alter data are 
disabied. This aiiows an operator to program or verity 
without accidently altering data. Only the functions listed 


mernitan ian tha 
below aré permitted when the Lock Data On function is 


selected: 


e Copy operations that move data from RAM to the port 
or device 


e Verify operations 
e Abort the operation in progress 
e Release data lock 


Use the following procedure to select the Data Lock On 
function: 


= 


to select the select function. 


29B Displays 
I err Crone 
SELELT LOUE wn 


2 fet #4 


The prompi iA) foiiowing “SELECT CODE” on ine 
display means that the two character hex select function 
code must be entered before the procedure can 
continue. 


—— Cyt) 


to select the data lock on function. 


29B Displays 
cI err Crone [- 7 
GEL i LU UE are 4 
——— 
= 
LS 
298 Displays 
TINT Mm 
LULK DARTH GN kx 


Lock Data On is enabled. 


The Lock Data On feature is now enabled. RAM altering 
operations cannot now be performed until the Data Lock 
On function is released. 
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Use the following procedure to release the Data Lock On 
function: 


— 


to select the select function. 


SELECT 


(i 


29B Displays 


PHSSWORD ? 


— 


to prepare for release data lock. 


kc 


PORT 


(a) 


29B Displays 


PROSWORD 


—— 
ss Fl 


to release data lock. 


o 


29B Displays 


SELECT. CORE 


Enter a select code for a select command if desired; 


otherwise, press either the COPY, VERIFY or EDIT key 


to begin the next operation. Data Lock On has now 
been released, and RAM data can be altered. 


F4 NIBBLE MODE Command 


Use the following procedure to select a 4-bit word size for 


1/O transfers regardless of the word size defined by 


default, or the programming module family/pinout. Use the 


F8 (BYTE/NIB MODE) select command to return to the 
word size defined by the programming module when the 
Nibble Mode is no longer desired. 


= 


to select the select function. 
29B Displays 


riocrr CmMNnce 
CEL | Loyd ‘N 
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The prompt (A) following ‘‘SELECT CODE” on the 
display means that the two character hex select function 
code must be entered before the procedure can 
continue. 


—— realty 


to select the nibble mode function. 


29B Displays 


\ ooo 
= 
A) 


29B Displays 


n 
! 


= 
bel 
bel 
= 
> 
C3 
m 


—— 
es (3 
JN 


to enable the nibble mode. 
29B Displays 


NIBBLE MODE 


the nibble mode is enabled. 


KK 


F5 BINARY BASE Command 


Use the following procedure to set the number base for 
Edit operations to binary: 


— 


to select the select function. 


29B Displays 
| ~r -Crmane\;e 
SEL oe Lt wo IN 


The prompt (A) following “SELECT CODE” on the 
display means that the two character hex select function 
code must be entered before the procedure can 
continue. 
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to select the binary base function. 


29B Displays 


29B Displays 


rere AO, 


to set the number base to binary for Edit operations. 


29B Displays 


[BINARY BHSE xX] 


the binary base selection is complete. 


FE OCTAL BASE Command 


Use the following procedure to set the number base for 
Edit operations to octal: 


f= 


to select the select function. 


29B Displays 


GELELT CODE» 


The prompt (A) following “SELECT CODE” on the 
display means that the two character hex select function 
code must be entered before the procedure can 
continue. 


2 old 


to select the octal base function. 
29B Dispiays 


SELECT CUBE  »Fb 


2 ) = { 


29B Displays 


Ae TARE 


BASE 


_— 
ond 
oN 


to set the number base to octal for Edit operations. 


29B Displays 
wie TA 
UL | BHSE 


the Saal base selection is oe 


F7 HEX BASE Command 


Use the following procedure to set the number base for 
Edit operations to hexadecimal: 


=F 
ip q 


to select the select function. 


29B Displays 


The prompt (A) following ‘““SELECT CODE” on the 
display means that the two character hex select function 
code must be entered before the procedure can 
continue. 


—- Clty 


to select the hex base function. 


29B Displays 
rerr Fmnce 7 
SELEL | LoL Ue nhs 


oo 
= 
SN 


29B Displays 


HEX BASE ag 
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\ 
— 
a 


to set the number base to hex for Edit operations. 
29B Displays 


HEX BASE eX 


the hex base selection is complete. 


F8 BYTE/NIB MODE command 


Use the following procedure to nullify select function F4, 
allowing the word size defined by the programming module 
to take effect: 


=< 


to select the select function. 


29B Displays 


Pie FE 
6 f= Louw Jo ‘N 
The prompt (A) following ‘““SELECT CODE” on the 
display means that the two character hex select function 


code must be entered before the procedure can 
continue. 


is Cele] 


to select the byte/nibble mode function. 


29B Displays 


EI 


29B Displays 


ee 
= 
A aera 


to disable the nibble mode (F4) returning the 
system to the device word size. 


29B Displays 


3.8.6 SERIAL 1/0 OPERATIONS 


D7 LEADER OUTPUT Command 


Use the following procedure to send 50 nulls from the 
serial port: 


= 


to select the select function. 
29B Displays 


BEG 


Bes Trmny 
I a 


rm 


The prompt (A) following ““SELECT CODE” on the 
display means that the two character hex select function 
code must be entered before the procedure can 
continue. 


2 


to select the leader output function. 


29B Displays 
Coinerr crnne Tl? 
SELEL | ae Be wide 
Oooo 
E> LI 
CS 
29B Displays 


‘Es Le] 


to output 50 nulls from the serial port. 
29B Displays 


LEACH GUTPUT x 


10-990-0013 


Dg SIZE RECORD Command 


Use the following procedure to change the number of 
bytes per data record on the serial output (the value 
entered must be in hexadecimal): 


to select the select function. 
29B Displays 


SECEET 


LUE a 


The prompt (A) following “SELECT CODE” on the 
display means that the two character hex select function 
code must be entered before the procedure can 
continue. 


to select the size record function. 


29B Displays 


— 


29B Displays 


SIZE RECA1G TG 


the default entry in the hex field is 10 (16 decimal). 


to set the record size. (Step can be skipped if the 
default or current entry is correct.) 


29B Displays 


[STE REC AHH Ta 
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5. jy f aia | 


29B Displays 


[SIZE REL ORT i K K | 


eft POCUNY RM 
the size record selection is complete. 


D9 NULL COUNT Command 


Use the following procedure to set the null count following 
each data record or line (carriage return and line feed) on 
the output. The hex entry selects from 0 (00) to 254 (FE) 
nulls. An entry of 255 (FF) sends no nulls and suppresses 
the line feed. The default entry on power-up is 1 (01) null. 


= 


to select the select function. 


29B Displays 
GELELT CORE 4 


The promot A} following “SELECT CODE” on the 
display means that the two character hex select function 


code must be entered before the procedure can 
continue. 


—— 


to select the output null count function. 


29B Displays 
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Es FIG 


to set the hex null count. (Step can be skipped if 
the default entry is correct.) 


29B Displays 


Tri 
Lege 


nit 
wd 


nH DY 


— 
= Le 
eS 


the null count is fixed until a new entry is made. 


29B Displays 


F9 TIMEOUT OFF Command 


The Timeout Off command is used to disable the 
25-second timeout during |/O operations. The 25-second 
timeout (active unless disabled) is the maximum time the 
29B will wait for data when receiving or wait for the 


receiver of data before sending. Once the timeout has been 


—— = 
aa 
CC 


29B Displays 


TIMEQGUT OFF ry 
\ eo 
= 
CN 


29B Displays 


LEIMEGUT UFF KK] 


the timeout function is disabled. 


FA CHAR OUTPUT Command 


Use the following procedure to enter the hex code for an 


ASCIil character (see Appendix D) which will be 


transmitted to the port each time START is pressed (this 


function is inhibited in system remote control): 


— 


to select the select function. 


disabled the only way it can be enabled is to turn the 29B 


power off, and then reapply power. 


Use the following procedure to disable the 25-second 
timeout feature: 


— 


to select the select function. 


29B Displays 
~~ corr rane: 
GELEL! Lu ue ‘NN 


The prompt (A) following “SELECT CODE” on the 


display means that the two character hex select function 


code must be entered before the procedure can 
continue. 


= old 


to select the timeout function 
29B Displays 


SELECT CODE ar 


29B Displays 


iN 


The prompt (A) following ‘“‘“SELECT CODE” on the 
display means that the two character hex select function 
code must be entered before the procedure can 


continue. 


—— Celtel 


to select the character output function. 
29B Displays 


SELECT CORE FA 


ey 
oe ce) 
CS 


29B Displays 


ne oO 


TL 
Lt 


tit 
Lj 


fa} iT Ara 

Lj i he me) 
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— ow 7, a ia [el | 


to enter the hex code for the ASCII character to be to select the enable port function. 
transmitted. (Step can be skipped if the default 
entry is correct.) 29B Displays 


CHAR OUTPUT o.HA 


29B Displays ENABLE matinee FH 
= MiTotIT Tw 
Lite Gu eu = XH 
the prompt flashes momentarily. i —_ [om | 
CS 
29B Displays 
29B Displays 


mln ci iT fl iT b4t4 
Lr cee Lf WN = 
ENABLE PORT ¥ x 


the system remote control is enabled. 


6. To retransmit the same character return to step 5. To 

transmit a different character return to step 4. FC REMOTE ON OFF Command 
Use the following procedure to enter hex codes for ASCII 

FB ENABLE PORT Command characters that can be used to turn remote control on or 


Use the following procedure to enable system remote off (may be used with CRC, SRC or TRC): 


control and input interrupt. This also forces the RTS line 


high at all times for remote control from peripheral : 
gh ata es for r ntrol from peripherals =, [=] 


requiring a hardware handshake. The default at power-up L 


. . . ' Mine 
is RTS low and system remote control and serial interrupts : 
. to select the select function. 
disabled. 
29B Displays 

(Fs 

| Tr -rnne 
: G f- Bl ts Ps bey f- N 
to select the select function. 
29B Displays The prompt (A) following ‘“SELECT CODE” on the 


display means that the two character hex select function 
code must be entered before the procedure can 
continue. 


The prompt (A) following “SELECT CODE” on the : aa | 
display means that the two character hex select function 2. oS ia (¢} 
code must be entered before the procedure can — 
continue. to select the remote on or off function. 


29B Displays 
SELEC! CODE art 
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mo 


eae: p wera: 
29B Displays 
hA PES 
iT fii Pir roartt 1 Hi 


to select the hex ON code. (Step can be skipped if 
the default entry is correct.) 


to enter the hex ON code. 


OFF 


Htahirt 


to select the hex OFF code. (Step can be skipped if 
the default entry is correct.) 


29B Displays 


ree 


=. 


Ue HA HH 


ra] 
LJIN 


On; 


the remote on off entry is complete. 


29B Displays 
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3.9 REMOTE OPERATION 


The programmer can be operated externally using three 
different remote control modes. Two of the modes are 
standard to the programmer and are described in this 
section. They are the Computer Remote Control (CRC) and 
System Remote Control (SRC). The third mode is the 
optional Terminal Remote Control (TRC) mode which is 
covered in Appendix B of this manual. 


CRC is the preferred mode of operation and should be 
used for all new driver designs. Both SRC and TRC are 
included mainly to accomodate user’s whose existing 
operations have software and/or hardware requiring either 
of those modes of operation. 


3.9.1 COMPUTER REMOTE CONTROL 


CRC is designed to enable control of the 29B Programmer 
by a computer. Linked directly to the programmer, the 
computer generates and sends commands to the 
programmer, determines variables for setting programming 
parameters (where needed), and reacts to information 
returned to it from the programmer. 


While these commands may be sent by an operator at a 
terminal, the commands and syntax described in this 
manual were designed to be easily incorporated into a 
computer program. 


Installation 


The 29B with CRC must be connected to the computer 
according to RS232C specifications. The function of each 
serial port pin connection is described in subsection 2.5 of 
this manual. Refer to table 2-2 to determine the necessary 
connector pins for serial data transfers. The programmer's 
baud rate, parity, and stop bit settings are described in 
subsection 2.5.2. 


Overview 


Figure 3-4 illustrates the basic components of the 29B 
under computer remote control. 29B CRC remote control 
operation is controlled by the user’s computer. The user 
must provide application software which will allow his 
computer to issue CRC commands and to interpret CRC 
responses. 


Data transferred between the computer and the 29B is 
generally in ASCII notation, encoded in the selected data 
translation format (see Appendix A), although straight 
binary transfer is also possible. 


Commands are generated by the computer according to 
the computer’s software or in response to keyboard 
entries. The computer sends commands to the 29B which 
executes the command (or tries to} and then sends back a 
response character. 
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{also shown on the table) shows how to use the table to 


; errors present for that character, zero would be 
| transmitted. The example error status word shown below 
| 
decode the error-status word format. 


| = | | | Use the following procedure to decode the error status 
| | | | 


word 80080087: 


TERMINAL COMPUTER 

1. The first character in the example is 8. This decodes to 
the most significant bit high (message bit 31) as the 
only bit used in the first character. This bit is present 

VERIFY DIRECT whenever there is an error in the message; however it 


PROGRAM 


$e LINK . , : 
LOAD <> does not define whether the error is a programming, 


? 1/0, or RAM error. Since only bit 31 is used in the first 
PROGRAMMER character, it will always be either 8 or 0. 


2. The second character is 0 showing there are no receive 

errors. Message bits 24, 25, and 26 only carry 
information in this group; therefore, it will range in 
Response Characters magnitude between 0 (no errors) and 7 (all three 
possible receive errors). 


Figure 3-4. Computer Remote Control Components 


The programmer sends a response character to the 


computer after every command; table 3-4 summarizes these 3. The third character (first in the programming errors 
characters. A >‘ symbol for a response means that the group) is C. This decodes as errors present for message 
command was successfully executed. Whenever an error bits 22 (start line not set high) and 23 (device-related 
occurs, the 29B will send an F to the computer. The error). All four message bits (20 through 23) are used so 
computer or the operator can respond by interrogating the the possible combinations range from 0 (no errors) to F 
programmer with the X or F command. The X command (all four errors). 


causes the programmer to send the computer a complete 
list of the last sixteen error codes (described in Appendix & 
of this manual) that have occurred. The F command codes 
all errors into a 32-bit error status word. 


- 


. The fourth character is 8. This decodes as an error 
nresent for message bit 19 (device not biank). Aji four 
message bits (16 through 19) are used so the possible 
combinations range from 0 to F. 

The error status word format is shown in table 3-5. The 

table shows that the eight-character word is broken into 

four two-character groups. The first two-character group 
defines receive errors, the second group defines 
programming errors, the third group defines |/O errors and 
the last group defines RAM errors. Each two character 
group contains a maximum of eight bits, with each bit 
representing the presence of the defined error or error 
type. Multiple errors within a character do occur; therefore, 
if all four bits within the character are used and present the 
transmitted character would be F, while if there were no 


5. The fifth character (first in the i/O errors group) is 0. 
This shows that there are no errors for this character. 
Only message bits 12 and 15 are used in this character; 
therefore, the only characters possible are 0, 1, 8, 
and 9. 

6. The sixth character is also 0, showing again that there 
are no errors for this character. All four bits are used 
(message bits 8 through 11) so the characters possible 
range from 0 to F. Since both the fifth and sixth 
characters are 0 there are no I/O errors. 


Table 3-4. Response Characters 


Character Description 


Sent on entering remote control, after an ESCAPE or 
BREAK key has halted a command, or after a command has 
been successfully executed. The programmer then transmits 
a carriage return. 


Informs the computer that the programmer has failed to 
execute the last command entered. The programmer then 
transmits a carriage return. 
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Table 3-5. Error-Status Word 


Bit 


Number Value 


RECEIVE ERRORS 


PROGRAMMING ERRORS 


I/O ERRORS 


RAM ERRORS 


Op-NW ASPTAON 


EXAMPLE: 
What errors are indicated in this error status word: 80080081 


the word contains error information 
no receive errors 
(= 8 + 4): 8 = Device-related error 
4 = Start line not set high (error 26) 
device is not blank (error 20) 
no input errors 
no input errors 
RAM error (error 62, and possible 64 and 66) 
RAM end is not on 1K boundary (error 62) 


Description 


ANY ERROR. If the word contains any errors, the most 
significant bit (bit 31) will be high. 

Not used 

Not used 

Not used 


Not used 

Serial-overrun error (42) 

Serial-framing error (41, 43) 

Buffer overflow, i.e., > 15 characters (48) 


Any device-related error 
Start line not set high (26) 
L2 + L3> Device 
Composite DAC error 


Device not blank (20) 

Illegal bit (21) 

Nonverify (23, 24, 29) 

Incomplete programming, or no card set (22, 25, 30-39) 


1/O error (46, 50, 58, 59, 94, 95 or any 1/0 error) 
Not used 

Not used 

Compare error (52) 


Sum-check error (82) 

Record-count error, MOS Technology (93) 
Address-check error, Signetics and Tek Hex (92) 
Record-type error, Intel Intellec 8/MDS (94) 
Address error, i.e.,> word limit (27, 28, 51, 56, 57) 
Data not hexadecimal (84, 85, 91) 

Insufficient data received, ASCII-Hex and Octal (54) 


RAM-hardware error (64, 66 or any RAM error) 
Not used 

L2 + L3> RAM (in RAM-RAM block move) 
Invalid center point for split or shuffle 


lilegal split or shuffle 

No RAM or insufficient RAM resident (61) 

RAM write error, or program-memory failure (63) 
RAM and not on 1K boundary (62) 


NOTES 


fa.) The numbers in parentheses are 29B error codes, 
defined in Appendix E. 


(b.) An error can cause as many as 3 bits to be high: the bit 
which represents the error, the most significant bit of the 
8-bit word in which the error bit occurs, and bit 31. 


(c.) After being read, the error-status word resets to zeros. 
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. The seventh character (first in the RAM errors group) 
is 8. This decodes as an error present for message bit 7 
(RAM hardware error). Message bit 6 is not used so 
possible combinations are 0, 1, 2, 3, 8, 9, 10, and 11. 


. The eighth character is 1 which decodes for an error 
in message bit 0 (RAM end not on 1k boundry). All 
four bits are used (message bits 0 through 3) so the 
characters possible range from 0 to F. 


When a command is invalid or not understood by the 
programmer, it will send a “’?.‘’ When this occurs, examine 
the last command entered, check its validity, make the 
neccesary changes or corrections, and reenter the new or 
corrected command. 


Entering and Exiting Remote Control 


To enter CRC use select function F1 (see section 3-8). 
While in CRC the programmer display will show REMOTE 
MODE. On entering remote control, the programmer will 
retain all RAM data. 
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To exit CRC via the 29B keyboard, press any of the four 
blue mode keys. To exit via the computer, use Z RETURN. 
The programmer will retain all RAM data and operating 
parameters except the address offset. 


Command Summary 


A summary of CRC commands is given in table 3-6. The 
table response column ends with the symbols “> CRLF.” 
These represent the prompt (>) that appears on the 
terminal display, and the carriage return (CR) and line feed 
(LF) that are transmitted after the command has been 
sucessfully completed. The line feed is present only if the 
null command (U) has defined the null count to any hex 
value between “00” and “’FE.”’ The default null count is 
hex “FF” which results in line feeds being suppressed. A 
detailed explanation of the CRC commands follow the 
summary table. 
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Type of 
Command 


CONTROL COMMANDS 


UTILITY COMMANDS 


DEVICE COMMANDS 


1/0 COMMANDS 


EDITING COMMANDS 


HANDLER COMMANDS 


* Line feed is optional 


Table 3-6. Command Summary 


Command 


RETURN 
ESCAPE 
BREAK 


nT 


PP@ 


AGCe2ZmMo << UVUTFaATwWANTXK MT 


(a) Response occurs after data transmission with the proper termination. 


Name 


Execute 
Abort 
Abort 


Software Configuration 
Set Begin RAM 

Set Block Size 

Set Begin Device Address 
Select Extended Function 
Sum-check 

Error-Status Inquiry 
Error-Code Inquiry 

No Operation 

Escape Remote Control 


Illiegal-Bit Test 

Blank Check 

Family and Pinout inquiry 
Select Family 

Respond 

Load 

Program 

Verify 


Select Odd Parity 

Select Even Parity 
Select No Parity 

Set 1 Stop Bit 

Set 2 Stop Bits 

Select Translation Format 
Select Record Size 

Set Nulls and Line Feeds 
Set Address Offset 
Disable Timeout 

Input 

Output 

Compare 

Parity-Error 


Swap Nibbles 
RAM-RAM Block Move 
Split RAM Data 
Shuffle RAM Data 
Clear All RAM 


Handler Start 
Binning Control 


3-40 
10-990-0013 


Response* 


> CRLF 
> CRLF 


HHHH> CRLF 

> CRLF 

> CRLF 

> CRLF 

> CRLF 

HHHH> CRLF 
HHHHHHHH> CRLF 
HHHH> CRLF 

> CRLF 

None 


> CRLF 

> CRLF 

FFPP> CRLF 

> CRLF 
AAAA/B/C> CRLF 
> CRLF 

> CRLF 

> CRLF 


> CRLF 
> CRLF 
> CRLF 
> CRLF 
> CRLF 
> CRLF 
> CRLF 
> CRLF 
> CRLF 
> CRLF 
> CRLFia) 
> CRLFia) 
> CRLFie) 
0000> CRLF 


> CRLF 
> CRLF 
> CRLF 
> CRLF 
> CRLF 


> CRLF 
> CRLF 


Command Groups The handler commands are used only when the optional 
Handier is instalied on tne 29B. Refer to the table listed for 
each category of command for a detailed explanation of 
those commands. The characters (CR) are throughout the 
© Control Commands (Tabie 3-7) tabies to represent the carriage return key. 


CRC commands are divided into the foiiowing six 
catagories: 


© Utility Commands [Table 3-8) 

* Device Commands (Table 3-9) 
¢ 1/0 Commands (Table 3-10) 

* Editing Commands (Table 3-11) 
e Handler Commands Table 3-12) 


Table 3-7. Control Commands 


Command Description 


Carriage return character which executes each command. It must 
be sent to the programmer immediately after the command. All 


commands are ignored if not followed by a RETURN. 


Escape or Break These commands cause the programmer to unconditionally halt 
(abort) any operation in progress, output a >, and await further 


tat +r 
instructions from the computer 


Table 3-8. Utility Commands 


device word limit, or the limit defined by the ‘’:” (Block Size) 
command, whichever is smaller. Sum-check is defined in the 
Glossary in Appendix A. 


Error-Status F(CR) On this command, the programmer Inquiry returns a 32-bit word, 
| displayed as 8 hex characters, that codes errors accumulated. The 
error-status word resets to all zeroes after (III cca eae See table 3-5. 


Command Description 
| Software G(CR) On command, the programmer sends the 4-digit hex number 

Configuration representing the particular configuration or revision level of 

Number software resident in the 29B. 

Set Begin RAM HHHH< (CR) This command, preceded by a 4-digit hex address (HHHH), 

Address defines the first RAM address to be used for data transfers. It is 
also the RAM source address when used in a Block Move. The 
default value is 0. 

Set Block Size HHHH;(CR) Sets the hex number of bytes (HHHH) to be transferred. The 
default value is the programming module word limit for device- 
related operations or the RAM limit less the Begin RAM Address 
for 1/O operations; there is no default value for Block Moves. 

Set Begin Device HHHH:(CR) This command, preceded by a 4-digit Address hex address 
(HHHH), defines the first device address to be used for data 
transfers. It is also used as the RAM destination address when used 
in a Block Move. The default value is 0. 

Select Extended HH](CR) Accesses Select Functions or Select Codes (HH) carried in the 

Function extended software of some programming Paks. Consult the pro- 
gramming Pak manuals for more information. 

Sum-Check S(CR) This command instructs the programmer to calculate the 4-digit hex 
sum-check of RAM from 0 or Begin RAM to RAM word limit, 

| 
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Table 3-8. Utility Commands (Continued) 


Command Description 


Error Code Inquiry The programmer responds to this command with hex error codes 
previously stored. After execution, the error codes are cleared 
from memory. Appendix E of this manual lists and describes all 
the error codes. 


No Operation This is a null command and always returns a prompt (>). 


Escape Remote This command returns control to the Control 29B keyboard. All 
RAM data and operating parameters except the address offset are 
retained. 


Table 3-9. Device Commands 


Command Description 


Illegal-Bit Test Instructs the programmer to perform an illegal-bit test and stores 
the error code and returns an F if an illegal-bit occurs 
(programmed device bit whose corresponding RAM bit is 
unprogrammed). 


Blank Check Instructs the programmer to do a blank check (search the device 
for programmed bits) and store the error code and return an F if 
the device is nonblank. 


Family and Pinout The programmer responds to this command with the Family and 
Inquiry Pinout Codes of the selected device. Returns an F when using a 
programming module not requiring Family and Pinout Codes. 


Select Family and FFPP@(CR) Selects a 2-digit hex Family Code (FF) and a 2-digit hex Pinout 
Pinout Code (PP). This command is only valid when using programming 
Paks requiring Family and Pinout Codes. 


Respond The programmer checks the programming module or Pak and 

outputs: 

AAAA/ (device word limit) 

B/ (byte size), 

C 1 (VOL) or @ (VOH). 
A VOL device is one in which the programmed state is LOW, 
whereas a VOH device is one in which the programmed state is 
HIGH. 


This command instructs the programmer to load data into RAM 
from the device in the programming module, within the parameters 
defined by the Begin RAM Address, Block Size, and Begin Device 
Address. 


Program This command instructs the programmer to program the data in 
RAM into the device in the programming module, within the 
parameters defined by the Begin RAM Address, Block Size, and 
Begin Device Address. 


This command instructs the programmer to compare RAM data 
with the data of the device in the programming module, within the 
parameters defined by the Begin RAM Address, Block Size, and 
Begin Device Address. 
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Table 3-10. !|/Q Commands 


| Title Command Description | 


Select Odd Parity instructs the programmer to set odd parity for output data and 


inspect incoming data for odd narity. This command overrides the 


ree ALS we VN imu 


programmer's parity switch. The default value is the programmer's 


inspect incoming data for even parity. The E command overrides 
the programmer's parity switch. The default value is the 
programmer's parity-switch setting. 


Select No Parity N(CR) Instructs the programmer to not check incoming data for parity, 
and to output data without parity. The N command overrides the 
programmer's parity switch. The default value is the programmer’s 
parity-switch setting. 


Set 1 Stop Bit J(CR) On receiving this command, the programmer sets one stop bit for 
serial data transfers. The default value is the programmer’s stop-bit 
switch setting. 

Set 2 Stop Bits K(CR) On receiving this command, the programmer sets two stop bits for 
séfiai data transfers. The default vaiue is the programmer's stop-bit 
switch setting. 

Set Translation CFFA(CR) This command selects the instrument control code (C) and the 
format code (FF) used to define handshaking and data translation 
during serial |/O operations. The default values are- instrument 
contro! code zero (0) and MOS Technology Format -81. All the 
data translation formats available are detailed in Appendix A of 
this manual. 


rT 
parity-switch setting. 
Select Even Parity E(CR) Instructs the programmer to set even parity for output data and 


Select Record Size HHMI(CR) The 2 hex characters (HH) define the number of data bytes per 
record in serial-output operations. The default value is 16 bytes per 
record for data translation formats with a variable record size (all 
formats except ASCII-Binary, Spectrum, and Fairchild Fairbug). 


Clear All RAM A (CR) Clears all of the programmers data RAM to zeroes. 


Set Nulls HHU(CR) The 2 hex characters (HH) before U set the number of nulls to be 
output following the carriage return in serial-output operations, 
and enable line feeds. The default value is no nulls or line feeds. 
Entering FF before U will also invoke the default value. 


Disable Timeout = (CR) This command disables the 25-second I/O timeout. The timeout 
can be restored only by turning off the programmer and then 
turning it on again. 


Input Data (CR) This command instructs the programmer to accept formatted data 
from the computer. 


Output Data O(CR) This command instructs the programmer to translate RAM data 
into the selected data translation format and output this data to 
the computer. The programmer will stop outputting on receipt of 
the X-OFF character, DC-3 (CTRL S), and will resume on receipt 

of the X-ON character, DC-1 (CTRL Q). 
| 


Compare Data C(CR) This command instructs the programmer to compare data in RAM 
with data from the computer. 


Parity-Error Y(CR) This command instructs the programmer to output the hex number | 
of parity errors (up to FFF) encountered since power-on, since the 
last Y command, or since the last parity command (D, E, or N). 
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Table. 3-11 Editing Commands 


Command Description 


Swap Nibbles Instructs the programmer to exchange high- and low-order halves 
of every word in RAM. This is useful when programming 4-bit 
devices with only one-half of RAM at a time. 


RAM-RAM Block Move \ (CR) This command moves a specified number of bytes (as specified by 
the Block Size) from one RAM location (as specified by the Begin 
RAM Address) to another (specified with the Begin Device 
Address Command). 


Split RAM Data HHHH?(CR) For 16-bit microprocessor data; complement of Shuffle RAM Data | 
(below). After a block of data is input or loaded to RAM (each 
sequential pair of 8-bit bytes representing a 16-bit word), the 
command “‘splits” the block into two adjacent blocks, separated 
by the specified center point (HHHH). The split stores the even- 
numbered 8-bit bytes of each byte pair in sequence from address 0 
to the center point; odd-numbered bytes are stored in sequence at 
addresses beginning at the center point. The reorganized data 
occupies the same original block in RAM. 


Each block of data can then be programmed into an 8-bit device, 
and the two devices can be addressed in parallel (while in use) to 


deliver 16-bit words to the processor. 


Typically, the center point will equal the number of words in the 8- 
bit device to be programmed. In any event, it must meet two 
requirements: 


1. It must be a power of 2. 
2. It must be less than or equal to half the size of the resident 
RAM. 


The center-point default value is the RAM midpoint. 


Shuffle RAM Data HHHH> (CR) For 16-bit microprocessor data. Complement of Split RAM Data, 
this command merges into one block the two adjacent blocks of 
data which meet at the specified center point address (HHHH). 
Two 8-bit devices are first loaded adjacent to each other in RAM, 
beginning a address 0, to create the two blocks, which are then 
merged for serial transfer. The center point must be a power of 2 
between 0 and RAM midpoint. The center-point default value is 
the RAM midpoint. 


Address Offset HHHHW(CR) This command specifies the value to be subtracted from addresses 
on input and added to them on output. Up to eight characters (in 
some formats) can be input before this command. 


Table 3-12. Handler Commands 


Command Description 


Handler Start %(CR) This command puts the programmer into a waiting state until the 
handler indicates a start condition or the operator presses the 
START key on the programmer. Once the start condition has been 
received by the programmer it will output a prompt ‘‘> "’ symbol 
to the serial port and wait for another command. 


Binning Control H!(CR) Instructs the handler to distribute programmed and verified devices 
to the numbered (H) bin, which must be from 1 to 4. 
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3.9.2 SYSTEM REMOTE CONTROL 


The programmer's System Remote Control (SRC) capability 
allows you control of the programmer's operation from a 
Fa ee eee ae | Lanne mem mae. 


terminai. Once the controlling terminal nas been propeny 
interfaced to the programmer (see section 2), select 


+, en 
function FB (Port Enable} must be manually e 


the keyboard to enable SRC. 


ntarad from 
y enter wus 


Command Protocol 


The syntax for SRC is similiar to that of the front panel 
manual operations, using the source/destination syntax 
method described in section 3.5. When keying in 
commands from a terminal, the programmer recognizes the 
first two characters of each word (except REVIEW), as 
shown in table 3-13. 


Table 3-13. Command Entry in SRC 


KEYBOARD REMOTE CONTROL 
COMMAND COMMAND 

Copy CO(SP) 

Verify VE(SP) 

Select SE(SP) 

Edit ED(SP) 

Device DE(SP) 

RAM RA(SP) 

Port PO(SP) 


Nnovicvwe f 


The space bar [denoted by the letters (SP) as shown in 
table 3-13] is used after the command as a delimiter, 
setting the boundaries for that command. The programmer 
will not define the characters input until the space bar is 
entered. And, since the programmer only recognizes the 
first two characters, some variations are possible. For 
example; the command COPY from DEVICE address 
(XXXX) for block size of (YYYY) to RAM address (ZZZZ) 
can be written with the same result in either of the 
following ways: 


CO(SP)DE(SP)XXXX(SP)YYYY(SP)TO(SP)RA(SP)ZZZZ(CR) 


COPY(SP)DEVICE(SP)XXXX(SP)YYYY(SP)TO(SP)RAM(SP) 
ZZZZ\CR) 


NOTE 
The word “TO” must be keyed in before 
the destination when entering commands 
with SAC. 


In either example, the programmer will load the data in the 
device into the programmer RAM, in the same way as a 
Load from Device is done from the front panel keyboard. 
The carriage return (CR) at the end of the line acts as an 
execute key. Command characters are input to the 
programmer until the (CR) is entered, signalling the 
programmer to execute that line of characters. 


Command Entry 


There are two methods of command entry while using 
SRC, direct or interactive. in direct command eniry the 
fram tha tarminal Lavhaarad iieinn 


naa art 
commMmanas are eniterea TEU LIS LOMIG! NG ywuaru UoTliy 


the space bar between words as shown in the examples 
above (Command Protocai naranranh). Entry of the > Xx, Y, 


www poy Sp 


and Z values is optional, if they are not included the 
programmer uses either the last valid entry or the default 
value. 


The interactive method streamlines the entries required of 
the operator. The operator keys in the function, then 
presses (CR). In return, the terminal displays a prompt 
similiar to those displayed on the programmer display. For 
example, if the CO (CR) is entered for a Copy command, 
the terminal would display COPY DATA FROM to prompt 
the operator of the next entry. Operation occurs just as it 
does when using the programmer’s keyboard except the 
commands are keyed in at the terminal. 


When entering data on the terminal, the slash {/) is used 
in place of the REVIEW key. When pressed, it causes the 
previous character(s), prior to a space bar entry, to be 
ignored. The characters are stiii dispiayed on the screen; 
however, all entries back to the previous space bar are 
ignored and the operator can enter the replacement 
characters. 


Inputting Parameters 


The parameters required are given in figure 3-5. The 
characters entered must be valid 4-digit hexadecimal 
vaiues. When the default value is satisfactory, no new 
value needs to be entered. If it is necessary to skip over 
the source address (when its default is correct) and change 
the block size, input a comma (,) or space bar (SP). 


SRC Operations 


When a command is sent to the keyboard using SRC the 
programmer reacts the same as if a manual command had 
originated at the keyboard. When the command is entered, 
the programmer display reads the same as when the 
corresponding key is pressed on the front panel keyboard. 
The terminal display, while not identical with the 
programmer display, has approximately the same 
information. The 29B’s SRC can display both Select and 
Format menus on the terminal. The procedures that follow 
cover the commands available through SRC and show both 
the terminal and programmer display. 
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WHEN DEFAULT VALUES ARE ALL CORRECT: 


DIRECT ENTRY 

COyDEyTOyRAICR] 

INTERACTIVE 

CO[CR] 

(COPY DATA FROM > displayed on terminal) 
DEICR] 

(DEV ADDR,SIZE > displayed on terminal) 
TOyRAICR] 

(CO DEV > RAM ADDR > displayed on terminal) 


NOTE 


The commands shown here are examples 
only, The complete list of commands is 
in Table 3-6. 


WHEN NO DEFAULT VALUES ARE CORRECT: 


DIRECT ENTRY 

COyDEyXXXX, YYYYyTOyRAyZZZZICR] 
INTERACTIVE 

COICR] 

(COPY DATA FROM > displayed on terminal) 
DEICR) 

(DEV ADDR,SIZE> displayed on terminal) 

XXXX, YYYYyTOyRAICR] 

{COPY DEV> RAM ADDR > displayed on terminal) 
2ZZZ(CR] 


WHEN SOURCE ADDRESS DEFAULT IS CORRECT AND BLOCK 
SIZE DEFAULT IS INCORRECT: 


DIRECT ENTRY 

COyDEV, XXXXyTOyRAICR] 
INTERACTIVE 

COICR] 


(COPY DATA FROM > displayed on terminal) 

DEICR] 

(DEV ADDR,SIZE > displayed on terminal} 
LYYYYyTOyRAICR] 

(COPY DEV > RAM ADDR > displayed on terminaliCR] 


Figure 3-5. Inputting Remote Control Parameters 


COPY AND VERIFY COMMANDS. Use the following 
procedures to perform the copy and verify procedures 
using SRC. 


Load RAM with Master Device Data. Use the following 
procedure to load the 29B RAM with data from a master 
device using a remote terminal and SRC: 


C. SOE 


to select the mode. 
29B Displays 


LUPY JATA FROM 
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The terminal displays: COPY DATA FROM > 


Co. Boe 


to select the source of the data. 
29B Displays 


TEI An TIE TM 
EV, ADGDR/’SIZE TE 


The terminal displays the command and data in the 
following sequence: 


COPY DATA FROM > 
DEV ADDR, SIZE > 


. “ADDR” means that you can change the begin device 


address to any address within the range of device word 
limit by entering the hex value with the terminal. If an 
entry is not made the value defaults to zero (0). If a hex 
value appears in place of “ADDR” it is from a 
previously entered begin address. 


“SIZE’’ means that you can change the block size by 
entering the hex value with the keyboard. If an entry is 
not made the value defaults to device size. If a hex 
value appears in place of “SIZE” it is from a previously 
entered block size. 


NOTE 
If a begin address is specified then the 
size must be specified also. The size 
must be equal to or less than the device 
size minus the begin address. 


If the default or previously entered values are correct, 
disregard the XXXX and/or YYYY characters in this 
step representing the device address and block size 
respectively and enter only the terminal message 
“TO(SP)RA(CR).” If the values are incorrect, enter the 
data in the sequence below: 


XXXX, YYYY(SP)TO(SP)RA(CR) 
or 
TO(SP)RA(CR) 


29B Displays 


The terminal displays: 


COPY DATA FROM > 
DEV ADDR;,SIZE > 
CO DEV> RAM ADDR > 


4. “ADDR” means that you can change the begin RAM 


address by entering the hex value with the keyboard. If 
an entry is not made, the value defaults to zero (0). If a 
hex value appears in place of ““ADDR,” it is from a 
previously entered RAM begin address. 


if the default or previously entered values are correct, 
disregard the ZZZZ characters in this step renresenting 


the RAM address and enter only the terminal carriage 
return (CR). If the values are incorrect, enter the data in 
the sequence below: 


ZZZZ(CR) or (CR) 


29B Displays 
f. Cana [Ara fIT h CATA 
Pinwe Liv Wu 


The terminal displays data in the following sequence: 


COPY DATA FROM > 
DEV ADDR,SIZE > 

CO DEV> RAM ADDR > 
FAM HH PIN HH > 


NOTE 
If the Pak or programming module 
installed does not require a family/pinout 
code combination the 29B skips to the 
display in step 5. 


. Enter the 4-digit hex family/pinout code combination for 
the device to be copied. The codes are listed in the Pak 
or programming module manual. If a code combination 
appears on the display, it is from a previously entered 
code. 


If a previously entered family/pinout code is correct, 
disregard the HHHH characters in this step representing 
the family/pinout code and enter only the terminal 
carriage return (CR). If the code is incorrect, enter the 
correct code in the sequence below: 


HHHHI(CR) or (CR) 


29B Displays 


LUAL Bev ite 


Lu 


The terminal displays: 


COPY DATA FROM > 
DEV ADDR,SIZE > 
CO DEV> RAM ADDR > 


FAM HH PIN HH > 
LOAD DEVICE > 
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NOTE 
lf the pak installed has more than one 
socket, the LED next to the correct 
socket will illuminate. 


6. Insert and lock the master device into the appropriate 
socket. (See seciion 3.4.2). 


a 


29B Displays 


1mnranr sai 


ia 1 
Mmaiseipek ie ? 


BEVICE OG 


The terminal displays data in the following sequence: 


COPY DATA FROM > 
DEV ADDR; SIZE > 

CO DEV> RAM ADDR > 
FAM HH PIN. HH > 
LOAD DEVICE > 

(Cursor Returns) 


NOTE 
The amount of time the programmer will 
require to perform this operation will vary 
depending on the device size. The action 
symbol line rotates 360 degrees while the 
operation is taking place. When the 
operation is complete the following 
display signals the programmer's 
readiness. If an error code is displayed, 
see appendix E. 


29B Displays | 
LUAD GONE | HHHH 


The terminal displays data in the following sequence: 


COPY DATA FROM > 
DEV ADDR,SIZE > 

CO DEV> RAM ADDR > 
FAM HH PIN HH > 
LOAD DEVICE > 

(Cursor Returns) 

LOAD DONE HHHH > 


NOTE 
HHHH is the hex sumcheck of the data 
transferred, i.e., the hex sumcheck of 
RAM data starting at the begin RAM 
address and extending for a length of 
address locations equal to the device size 
minus the begin device address. 
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8. Remove the master device from the socket. 


9. To repeat the load operation, return to step 6. 


Load RAM From Serial Port. Use the following procedure 
to load the 29B RAM from front panel control, with 
incoming serial port data using a remote terminal and SRC: 


1. Set-up the serial port. Refer to Section 2. 


2. Select the appropriate data translation format from 
appendix A and execute the B3 (format number) select 
function (see section 3.8). 


(| Boe 


to select the mode. 


29B Displays 


Lure BATA FROM 


The terminal displays: 


COPY DATA FROM > 


‘EA 


to select the source of the data. 


29B Displays 


PURKADER/STZE TO 


The terminal displays data in the following sequences: 


COPY DATA FROM > 
POR ADDR,SIZE > 


5. “ADDR” in the display means that you can change the 
begin port address to any address within the range of 
format word limit (up to eight characters in length, 
determined by the format selected) by entering the hex 
value with the terminal. If an entry is not made, the 
value defaults to the first incoming address. If a hex 
value appears in place of “ADDR” it is from a 
previously entered begin address. 


“SIZE"" means that you can change the block size by 
entering the hex value with the keyboard. If an entry is 
not made, the value defaults to end of RAM address 
minus the begin RAM address. If a hex value appears in 
place of “SIZE,” it is from a previously entered block 
size, 


3-48 


If the default or previously entered values are correct 
disregard the XXXX and/or YYYY characters in this 
step representing the port address and block size 
respectively and enter only the terminal message 
“TO(SP)RA(CR).”’ If the values are incorrect, enter the 
data in the sequence below: 


XXXX, YYYY(SP)TO(SP)RA(CR) 
or 
TO(SP)RA(CR) 


29B Displays 


TO OF) PAM Anne 


The terminal displays data in the following sequence: 


COPY DATA FROM > 
POR ADDR,SIZE > 
CO POR> RAM ADDR > 


“ADDR” means that you can change the begin RAM 
address by entering the hex value with the keyboard. If 
an entry is not made, the value defaults to zero (0). If a 
hex value appears in place of “ADDR,” it is from a 
previously entered RAM begin address. 


If the default or previously entered values are correct, 
disregard the ZZZZ characters in this step representing 
the RAM address and enter only the terminal carriage 
return (CR). If the values are incorrect, enter data in the 
sequence below: 


ZZZZ(CR) or (CR) 


29B Displays 


INPUT PORT ut 


The terminal displays data in the following sequence: 


COPY DATA FROM > 
POR ADDR;,SIZE > 

CO POR> RAM ADDR > 
(Cursor Returns) 


NOTE 
The amount of time the programmer will 
require to perform this operation will vary 
depending on the block size. The action 
symbol line rotates 360 degrees while the 
operation is taking place. When the 
operation is complete the following 
display signals the programmer's 
readiness. If an error code is displayed 
see appendix E. 
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29B Displays 3. 


The terminal dispiays data in the f 
COPY DATA FROMT > 
POR ADDR;,SIZE > 
CO POR> RAM ADDR > 
(Cursor Returns) 
INPUT DONE HHHH > 


NOTE 
HHHH is the hex sumcheck of all data 
transferred to RAM. 


Program Device with RAM Data. When programming a 
device the 29B system performs an illegal bit test and a 
blank check at nominal Vcc to verify the ability of the 
PROM to accept programming before it begins the 
operation. Use the following procedure to program a blank 
device with data from RAM using a remote terminal and 
SRC: 


faclolo 


to select the mode. 


29B Displays 


Tmtiw 


ye ee 


The terminal displays: 


COPY DATA FROM > 


(L\. 


to select the source of the data. 


29B Displays 


RAM ADDR / SIZE TO 


The terminal displays data in the following sequence: 


COPY DATA FROM > 
RAM ADDR;SIZE > 
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“ADDR” in the display means that you can change the 
begin RAM address to any address within the range of 
RAM word limit by entering the hex value with the 
terminal. If an entry is not made, the value defaults to 
zero (Q). If a hex value appears in place of ““ADDR’”’ it is 
from a previously entered begin address. 


“SIZE” means that you can change the block size by 
entering the hex value with the keyboard. If an entry is 
not made the value defaults to the device size. If a hex 
value appears in place of “SIZE,” it is from a previously 
entered block size. 


NOTE 
If the begin device address is specified 
then the size must be specified also. The 
size must be equal to or less than the 
device size minus the begin device 
address. . 


if the default or previously entered values are correct, 
disregard the XXXX and/or YYYY characters in this 
step representing the RAM address and block size 
respectively and enter only the terminal message “’TO 
DE(CR).” If the values are incorrect, enter the data in 
the following sequence: 


XXXX, YYYY(SP)TO(SP)DE(CR) 


29B Displays 


LU RAM: DEV WAU OR 


The terminal displays data in the following sequence: 


COPY DATA FROM > 
RAM ADDR;,SIZE > 
CO RAM> DEV ADDR > 


“ADDR” means that you can change the begin device 
address by entering the hex value with the keyboard. If 
an entry is not made, the value defaults to zero (0). If a 
hex value appears in place of “ADDR,” it is from a 
previously entered device begin address. 


If the default or previously entered values are correct, 
disregard the ZZZZ characters in this step representing 
the device address and enter only the terminal carriage 
return (CR). if the values are incorrect, enter the data in 
the sequence below: 


ZZZZ(CR or (CR) 


NOTE 
If the Pak or programming module 
installed does not require a family/pinout 
code combination the 29B automatically 
skips to the display in step 5. 


29B Displays 


The terminal displays data in the following sequence: 


COPY DATA FROM > 
RAM ADDR; SIZE > 

CO RAM> DEV ADDR > 
FAM HH PIN HH > 


. Enter the four digit hex family/pinout code combination 
for the device to be copied. The codes are listed in the 
pak or programming module manual. If a code 
combination appears on the display, it is from a 
previously entered code. 


If a previously entered family/pinout code is correct, 
disregard the HHHH characters in this step representing 
the family/pinout code and enter only the terminal 
carriage return (CR). If the values are incorrect, enter 
data in the sequence shown below: 


HHHH(CR) or (CR) 


29B Displays 
a a as 
PROGRAM TEVWICE 


The terminal displays data in the following sequence: 


COPY DATA FROM > 
RAM ADDR; SIZE > 

CO RAM> DEV ADDR > 
FAM HH PIN HH > 
PROGRAM DEVICE > 


NOTE 
If the pak installed has more than one 
socket the LED next to the correct 
socket will illuminate. 


. Insert and lock the device to be programmed into the 
appropriate socket. (See section 3.4.2). 


{or} 


NOTE 
The amount of time the programmer will 
require to perform the test, program, and 
verify operations will vary depending on 
the device size. The action symbol line 
rotates 360 degrees while the operations 
are taking place. As each operation is 
completed in turn, the following displays 
signal that the programmer has 
completed each step. If an error code is 
displayed, see appendix E. 


29B Displays 


TEST DEVICE i 


The terminal displays data in the following sequence: 


COPY DATA FROM > 
RAM ADDB;SIZE > 

CO RAM> DEV ADDR > 
FAM HH PIN HH > 
PROGRAM DEVICE > 
(Cursor Returns) 


29B Displays 


PROGRAM DEVICE G 


The terminal displays data in the following sequence: 


COPY DATA FROM > 
RAM ADDR;,SIZE > 

CO RAM> DEV ADDR > 
FAM HH PIN HH > 
PROGRAM DEVICE > 
(Cursor Returns) 

(No Change) 


29B Displays 


Taw T me 
VERTE y REV T! = im 


The terminal displays data in the following sequence: 


COPY DATA FROM > 
RAM ADDR;SIZE > 

CO RAM> DEV ADDR > 
FAM HH PIN HH > 
PROGRAM DEVICE > 
(Cursor Returns) 

(No Change) 

(No Change) 
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298 Displays 


[PRG DONE NN HHH 


The terminal displays data in the tollowing sequence: 


COPY DATA FROM > 

RAM ADDR; SIZE > 

CO RAM> DEV ADDR > 

FAM HH PIN HH > 

PROGRAM DEVICE > 

(Cursor Returns) 

(No Change) 

(No Change) 

PRG DONE NN HHHH> 5 


NOTE 
NN is the decimal sequence number 
(number of devices that have been 
programmed since the last time the 
counter was reset or power was applied 
to the programmer). HHHH is the hex 
checksum of the device data 
programmed by this operation. 


8. Remove the device from the socket. 
9. To repeat the ioad operation, return io siep 6. 


Output to Serial Port. Use the following procedure to 
output data to the serial port using the remote terminal and 
SRC: 


1. Set-up the serial port. Refer to Section 2. 


2. Select the appropriate data translation format from 
appendix A and execute the B3 (format number) select 
function (see section 3.8). 


‘Cl. GOS 


to select the mode. 


29B Displays 
LUPY DRTAR FROM 


The termina! displays: 


COPY DATA FROM > 
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The terminal displays data in the following sequence: 


COPY DATA FROM > 
RAM ADDR,SIZE > 


. “ADDR” in the display means that you can change the 


begin RAM address to any address within the range of 
RAM word limit by entering the hex value with the 
terminal. If an entry is not made, the value defaults to 
zero (0). If a hex value appears in place of “ADDR” it is 
from a previously entered begin address. 


“SIZE” means that you can change the biock size by 
entering the hex value with the keyboard. If an entry is 
not made, the value defaults to the RAM size minus the 
begin RAM address. If a hex value appears in place of 
“SIZE,” it is from a previously entered block size. 


if the defauit or previousiy entered vaiues are correct 
disregard the XXXX and/or YYYY characters in this 
step representing the device address and block size 
respectively and enter only the terminal message “TO 
PO(CR).” If the values are incorrect, enter data in the 
sequence shown below: 


XXXX, YYYY(SP)TO(SP)PO(CR) 
or 
TO(SP)PO(CR) 


29B Displays 


LU RAM POR nAior 


The terminal displays data in the following sequence: 


COPY DATA FROM > 
RAM ADDR, SIZE > 
CO RAM> POR ADDR > 


. “ADDR” means that you can change the begin port 


address by entering the hex value with the keyboard. If 
an entry is not made, the value defaults to zero (0). If a 
hex value appears in place of “ADDR,” it is from a 
previously entered port begin address. 


If the default or previously entered values are correct, 
disregard the ZZZZ characters in this step representing 
the port address and enter only the terminal carriage 


Block Move. Use the following procedure to move data 
from one location in RAM to another using the remote 
terminal and SRC: 


return (CR). If the values are incorrect, enter data in the 


sequence shown below: 


ZZZZ(CR) or (CR) 


29B Displays 


mil 
Lit 


The terminal displays data in the following sequence: 


COPY DATA FROM > 

RAM ADDR; SIZE > 

CO RAM> POR ADDR > 

(formatted data file scrolls on terminal display) 


NOTE 
The amount of time the programmer will 
require to perform this operation will vary 
depending on the data in RAM. The 
action symbol line rotates 360 degrees 
while the operation is taking place. 


. When the operation is complete, the following display 
signals the programmer's readiness. If an error code is 
displayed, see appendix E. 


29B Displays 
OUTPUT DUNE HHHH 


The terminal displays data in the following sequence: 


COPY DATA FROM > 

RAM ADDR,SIZE > 

CO RAM> POR ADDR > 

(formatted data file scrolls on terminal display) 
OUTPUT DONE HHHH> 


NOTE 
HHHH is the hex sumcheck of all data 
transferred. 


1 


2. 


3: 
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C\. BOE 


‘to select the mode. 


29B Displays 


The terminal displays: 


COPY DATA FROM > 


Bwololo 


to select the source of the data. 


29B Displays 
RAM AAUDR/ SIZE TY 


The terminal displays data in the following sequence: 


COPY DATA FROM > 
RAM ADDR; SIZE > 


“ADDR” in the display means that you can change the 
RAM begin address to any address within the range of 
RAM word limit by entering the hex value with the 
terminal. If an entry is not made, the value defaults to 
zero (@). If a hex value appears in place of “ADDR,” it 
is from a previously entered begin address. 


“SIZE” means that you can change the block size by 
entering the hex value with the keyboard. If an entry is 
not made, the value defaults to @. Block size must be 
specified. If a hex value appears in place of ‘‘SIZE,”’ it is 
from a previously entered block size. 


If the default or previously entered values are correct, 
disregard the XXXX and/or YYYY characters in this 
step representing the device address and block size 
respectively and enter only the terminal message ‘“TO 
RA(CR).” If the values are incorrect, enter data in the 
sequence shown below: 


XXXX, YYYY(SP)TO(SP)RA(CR) 
or 
TO(SP)RA(CR) 


29B Dispiays 
Oo RAM) RAM,ADGR | 


Lu eM} HM hu Lt 


The terminal displays data in the following sequence: 


COPY DATA FROM > 
RAM ADDR; SIZE > 
CO RAM> RAM ADDR > 


. “ADDR” means that you can change the new (move to) 
begin RAM address by entering the hex value with the 
keyboard. If an entry is not made, the value defaults to 
zero (0). If a hex value appears in place of ‘‘ADDR,”’ it 
is from a previously entered RAM begin address. 


If the default or previously entered values are correct 
disregard the ZZZZ characters in this step representing 
the RAM address and enter oniy the terminal carriage 
return (CR). If the values are incorrect, enter data in the 
sequence shown below: 


ZZZZ(CR) or (CR) 


29B Displays 

™ Ary move mM) 
(ALGER MOVE oy | 
OE bile 


The terminal displays data in the following sequence: 


COPY DATA FROM > 
RAM ADDR,SIZE > 

CO RAM> RAM ADDR > 
(No Change) 


NOTE 
The amount of time the programmer will 
require to perform this operation will vary 
depending on the device size. The action 
symbol line rotates 360 degrees while the 
operation is taking place. When the 
operation is complete the following 
display signals the programmer's 
readiness. /f an error code is displayed 
see appendix E. 


29B Displays 


BLOCK MUVE DUNE 
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The termina! displays data in the following sequence: 


COPY DATA FROM > 
RAM ADDR, SIZE > 


CO RAM> RAM ADDR > 
{No Change) 


Verify RAM Data Against Master Device Data. Use 
the following procedure to verify the data entered in the 
29B RAM duplicates the master device data, using the 
programmer front panel: 


1. 


ho 


(| oe 


to select the mode. 
29B Displays 


VERTEY DRT FROM 


The terminal displays: 


VERIFY DATA FROM> 


to select the source of the data. 


29B Displays 


Titles 


mn TVC T 
UEV aw DUR / Si ZE J 


4 
uJ 
The terminal displays data in the following sequence: 


VERIFY DATA FROM> 
DEV ADDR,SIZE > 


. “ADDR” in the display means that you can change the 


begin device address to any address within the range of 
the device word limit by entering the hex value with the 
terminal. If an entry is not made, the value defaults to 
zero (0). If a hex value appears in place of “ADDR,” it 
is from a previously entered begin address. 


“SIZE” means that you can change the block size by 
entering the hex vaiue with the keyboard. if an entry is 
not made, the value defaults to device size. If a hex 
value appears in place of “SIZE” it is from a previously 
entered block size. 


NOTE 
If a begin device address is specified then 
the size must be specified also. The size 
must be equal to or less than the device 
size minus the begin device address. 


If the default or previously entered values are correct 
disregard the XXXX and/or YYYY characters in this 
step representing the device address and block size 
respectively and enter only the terminal message ““TO 
RA(CR).” If the values are incorrect, enter the data in 
the sequence shown below: 


XXXX, YYYY(SP)TO(SP)RA(CR) 
or 
TO(SP)RA(CR) 


29B Displays 


VE TEV) RAM, ADD 


The terminal displays data in the following sequence: 


VERIFY DATA FROM> 
DEV ADDR,SIZE > 
VE DEV> RAM ADDR > 


. “ADDR” means that you can change the begin RAM 
address by entering the hex value with the keyboard. If 
an entry is not made, the value defaults to zero (0). If a 
hex value appears in place of “‘ADDR,”’ it is from a 
previously entered RAM begin address. 


If the default or previously entered values are correct, 
disregard the ZZZZ characters in this step representing 
the RAM address and enter only the terminal carriage 
return (CR). If the values are incorrect, enter data in the 
sequence shown below: 


2ZZZ(CR) or (CR) 


NOTE 
If the Pak or programming module 
installed does not require a family/pinout 
code combination, the 29B automatically 
skips to the step 5 display. 


29B Displays 


PAMaHH PIN HH 


The terminal displays data in the following sequence: 


VERIFY DATA FROM> 
DEV ADDR,SIZE > 

VE DEV> RAM ADDR > 
FAM HH PIN HH > 
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5. Enter the 4-digit hex family/pinout code combination for 


the device to be copied. The codes are listed in the Pak 
or programming module manual. If a code combination 
appears on the display, it is from a previously entered 
code. 


If a previously entered family/pinout code is correct, 
disregard the HHHH characters in this step representing 
the family/pinout code and enter only the terminal 
carriage return (CR). If the code is incorrect, enter the 
correct code in the sequence shown below: 


HHHH(CR) or (CR) 


29B Displays 


The terminal displays data in the following sequence: 


VERIFY DATA FROM> 
DEV ADDR,SIZE > 

VE DEV> RAM ADDR > 
FAM HH PIN HH > 
VERIFY DEVICE > 


NOTE 
lf the Pak installed has more than one 
socket the LED next to the correct 
socket will illuminate. 


. Insert and lock the master device into the appropriate 


socket. (See section 3.4.2). 


29B Displays 


VERIFY DEVI 


CE 


The terminal displays data in the following sequence: 


VERIFY DATA FROM > 
DEV ADDR,SIZE > 

VE DEV> RAM ADDR > 
FAM HH PIN HH > 
VERIFY DEVICE > 
(Cursor Returns) 


NOTE 
The amount of time the programmer will 4. 
require to perform this operation will vary 
depending on the device size. The action 
symbol line rotates 360 degrees while the 
operation is taking place. When the 
operation is complete, the following 
display signals the programmer's 
readiness. /f an error code is displayed 
see appendix E. 


29B Displays 


VE DEY DUNE HHHH 


The terminal displays data in the following sequence: 


VERIFY DATA FROM> 
DEV ADDR, SIZE > 

VE DEV> RAM ADDR > 
FAM HH PIN HH > 
VERIFY DEVICE > 
(Cursor Returns) 

VE DEV DONE HHHH 


NOTE 
HHHH is the hex checksum of the data 
verified. 


8. Remove the master device from the socket. 

9. To repeat the load operation, return to step 7. 

Verify RAM From Serial Port. Use the following 
procedure to verify the incoming serial port data using the 


remote terminal and SRC: 


1. Set-up the serial port. Refer to Section 2. 


2. Select the appropriate data translation format from 
appendix A and execute the B3 (format number) select 
function (see section 3.8). 


\ OOS 


to select the mode. 
29B Displays 


Werte’ DATA FROM 


The termina! displays: 


VERIFY DATA FROM> 
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The terminal displays data in the following sequence: 


VERIFY DATA FROM> 
POR ADDR,SIZE > 


. “ADDR” in the display means that you can change the 


begin port address to any address within the range of 
the port word limit by entering the hex value with the 
terminal. If an entry is not made, the value defaults to 
the first incoming address. If a hex value appears in 
place of “ADDR,” it is from a previously entered begin 
address. 


“SIZE” means that you can change the block size by 
entering the hex value with the keyboard. If an entry is 
not made, the value defaults to RAM size minus the 
begin RAM address. If a hex value appears in place of 
“SIZE,"’ it is from a previously entered block size. 


fab. Anf...ls H h 
it ing Gefault or previously entered values are correct, 


disregard the XXXX and/or YYYY characters in this 
step representing the port address and block size 
respectively and enter only the terminal message “TO 
RA(CR).” If the values are incorrect, enter data in the 
sequence shown below: 


XXXX, YYYY(SP)TO(SP)RA(CR) 
or 
TO(SP)RA(CR) 
29B Displays 


pf Pres PRAM), TUR 


The terminal displays data in the following sequence 


VERIFY DATA FROM> 
POR ADDR;,SIZE > 
VE POR> RAM ADDR > 


. “ADDR” means that you can change the begin RAM 


address by entering the hex value with the keyboard. If 
an entry is not made, the value defaults to zero (0). If a 
hex value appears in place of “ADDR,” it is from a 
previously entered RAM begin address. 


If the default or previously entered values are correct, 
disregard the ZZZZ characters in this step representing 
the RAM address and enter only the terminal carriage 
return (CR). If the values are incorrect, enter data in the 
sequence shown below: 


ZZZZ(CR) or (CR) 


29B Displays 


VERIFY PORT i 


The terminal displays data in the following sequence: 


VERIFY DATA FROM> 
POR ADDR,SIZE > 

VE POR> RAM ADDR > 
(No Change) 


NOTE 
The amount of time the programmer will 
require to perform this operation will vary 
depending on the device size. The action 
symbol line rotates 360 degrees while the 
operation is taking place. 


. When the operation is complete, the following display 
signals the programmer's readiness. If an error code is 
displayed, see appendix E. 


29B Displays 


WE POR TUNE HHHH 


The terminal displays data in the following sequence: 


VERIFY DATA FROM> 
POR ADDR;SIZE > 

VE POR> RAM ADDR > 
(No Change) 

VE POR DONE HHHH> 


NOTE 
HHHH is the hex sumcheck of all the 
serial port data verified. 


EDIT COMMANDS. The contents of the programmer 
RAM can be edited in remote with either the hexadecimal, 
octal or binary modes selected, just as from the front panel 
keyboard. The key sequence is given below for only the 
hexadecimal mode of operation. If one of the others is 
used, the operation is the same, the difference is in the 
manner in which the RAM data is displayed. The address is 
always displayed in hex, regardless of the mode selected. 
Refer to the manual procedure in section 3-7 if any 
question exists on the operation in the octal or binary 
modes. 


Use the following procedure to perform the Edit command 
while in the hex mode, operating with a remote terminal 
and using SRC: 


to select the mode. 


29B Displays 

~TNTT mT CATATATA 
EYL] Hu oR Bode 
The terminal displays: EDIT ADDR 0000 > 


2. Enter a hex address to be edited in the sequence shown 
below: 


HHHH(CR) 


29B Displays 
HHH HHA RHH 


The terminal displays data in the following sequence: 


EDIT ADDR 0000 > 
HHHH DHH,RHH > 
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3. “HHHH” in the display is the hex address in RAM 
where the data can be editted. ‘“‘DHH” is the hex data 
programmed into the device at the seiected address 
(** for data means that 

device). ‘RHH’ is the present hex data in the seiected 

RAM address. To enter the new hex data for the 


selected address, enter data in the sequence: 


address is undefined in the 


HH(CR) 
2SB Displays 


H dt 
HHHH DHEA RHH 
New address is previous address plus one. Data is 
from new address. 


The terminal displays data in the following sequence: 


EDIT ADDR 0000 > 
HHHH DHH,RHH > 
HHHH DHH,RHH > 


As long as new data is input followed by a return (CR) 
the address counter will be incremented by one for the 
next address. Exit the edit mode by pressing another 
mode key. 


NOTE 
If the data displayed is not to be 
changed, enter a carriage return (CR) to 
increment to the next data location or a 
slash (/) to decrement to the previous 
data location. 


SELECT COMMANDS. Select Commands can be entered 
with SRC by selecting either (S) (E) (space) (select hex 
code) (CR), or by entering directly the first two characters 
of the select command followed by a carriage return (CR). 
Entering (S) (E) (CR) will display a menu of all select 
codes. Refer to table 3-15 for a listing of the format codes. 


Use one of the following examples which illustrate the two 
methods to enter a select code. 


¢ The following example shows how to enter the Clear All 
RAM select function using the hex code: 


Enter: SE(SP)A4(CR). 


NOTE 
Always enter space bar between “SE” 
and the hex code. 


29B Displays 
LLLERR ALL RAM Xx) 


The terminal displays a prompt (>). 
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The following example shows how to enter the Clear All 
RAM seiect mode using the first two characters of the 


wie 
sele tan nal 
seisci commana. 


Enter: CL(CR). 


29B Displays 


LLEHR ALL RAM kK 


The terminal displays a prompt (> ). 


Table 3-14. Select Commands 


CODE TITLE 
Al SW Swap Nibbles 
A2 Fl Fill RAM 
A3 iN invert RAM 
A4 CL Clear All RAM 
A5 SP Split RAM 
A6 SH Shuffle RAM 
BO DE Device Size 
B1 SU Sumcheck RAM 
B2 SY System Config 
B3 FO Format Number 
B4 NO Nonblank Fail 
B9 Di Dispiay Test 
C1 CA Calibration 
D7 LE Leader Output 
D8 S| Size Record 
D9 NU Null Count 
FO PR Program Count 
F1 RE Remote Mode 
F2 29 29B TRC 
F3 LO Lock Data On 
F4 NI Nibble Mode 
F5 BI Binary Base 
F6 Oc Octal Base 
F7 HE Hex Base 
F8 BY Byte/Nib Mode 
F9 Tl Timeout Off 
FA CH Char Output 
FB EN Enable Port 
FC RE Remote On Off 


SECTION 4 
MAINTENANCE 


4.1 OVERVIEW 


WARNING 
The instructions contained in this 
section are for qualified service 
personnei only. Do not attempt to 
perform them unless you are 
qualified to do so. 


CAUTION 

When servicing Data I/O equipment 
beyond that described in this manual, 
we recommend that you send your 
unit to your local service center. If 
you decide to do the repair, be aware 
that many parts in Data I/O equip- 
ment have been qualified by vendor 
and may not be interchangeable with 
the same type of part manufactured 
elsewhere. Refer to the back of this 
manual for service office locations. 


The support material in this section has been provided to 
help you keep your 29B in good operating condition. 
General maintenance practices are discussed in sub- 
section 4.2 while basic troubleshooting procedures are 
described in subsection 4.4. For those 29B users who 
prefer to do their own calibration, power supply calibration 
procedures are provided in subsection 4.3. To complete the 
calibration cycle, perform a calibration of your Pak or 
module, with the 29B, by following the calibration 
instructions in your Pak (or module) manual. If you wish, 
you can also send your programmer and Pak to your 
nearest Data |/O Service Center for a complete calibration. 


4.2 MAINTENANCE 


Regular maintenance of the 29B consists of cleaning and 
inspecting the unit. To gain access inside the programmer, 
follow the procedures for cover removal in. sub- 

section 4.2.1. Also, remove the protective shield from 
inside the programmer's front panel opening by following 
the instructions in subsection 4.2.2. 


4.2.1 COVER REMOVAL 


To remove your 29B front panel cover, follow these 
procedures: 


WARNING 
To avoid electrical shock, disconnect 
the power cord before removing 
cover, panel or protective shield. 


—_ 
, 


wer off and remove the power 


2. Remove any programming Pak (or module) from the 
programmer (see section 2.3.1). 


4-4 


3. Turn the programmer upside down and remove the four 
screws at the corners of the base. 


4. Rett 


lie 
Live See 


nm tha 
Li 


nN einht+ nAgitinn 
mS PV a 


iGi ih PVoIUVil. 


5. Remove the cover by lifting it straight up. 


4.2.2 REMOVING THE CONTROLLER BOARD 
PROTECTIVE SHIELD 


A protective shield guards the interior of the programmer 
from dust and damage and protects the operator from 
shock. To remove it, do the following: 


1. Remove the Pak (see subsection 2.3.1). 


2. Remove the screw from the middle of the shield. 
3. With your thumbs, push back and pull-up on the shield 
clearing it from the connector. 


4. Lift the back edge out, pull the plate up slightly and 
turn it to the left until it clears the opening on the 
programmer's front panel. 


4.2.3 INSTALLING THE PROTECTIVE SHIELD 


1. Tilt the shield to one side and insert into Pak opening. 


2. Lower the shield into the programmer's front panel 
opening.. 


wo 


Fit the nlate over the Pak connector making sure the 


cutout for the dipswitch is on the right side. 


4. Push down on the shield until it fastens into place. 
Secure it with the screw removed earlier. 


4.2.4 CLEANING 


Clean the exterior of the unit with a mild detergent on a 
damp cloth. 


CAUTION 
Do not use caustic or abrasive 
agents; these will damage the 29B. 


Clean the fan filter (located on the top of the unit) every 
three months. Remove the filter and clean it with running 
water to rinse out accumulated dust. Dry it thoroughly 
before reinstalling. Press it back into its recessed location 
on the top of the programmer. 


4.2.5 INSPECTION 


You can help prevent malfunctions by periodically 
inspecting your 29B. Check cable connections, card 
seating, component mounting, etc., for proper seating, 
wear, and visible damage. 


If you find heat-damaged components, be particularly 
careful to find and correct the cause of the overheating to 
prevent further damage. 
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4.3 CALIBRATION 


WARNING 
To avoid electric shock always test 
for voltage before touching when 
working inside the equipment. 


Calibration of the 29B consists of checking and adjusting 
the power supplies. This will normally be performed as part 
of the calibration of a programming Pak (or module), as 
proper operation of the module depends on the 
programmer's power supplies. 


This manual explains how to calibrate the programmer's 
power supplies. The programming Pak’s (or module’s) 
instruction manual provides the procedures for calibrating 
the Pak (or module), and explains how to carry out these 
instructions on the 29B by providing specific key sequences 
and steps for entering and executing the calibration mode. 
Figure 4-1 demonstrates the calibration procedure. 


POWER SUPPLY 


MEASUREMENT SUBSECTION 


4.3.1 


SEE 
PROGRAMMING 
MODULE MANUAL 


DC CALIBRATION 


PERFORMANCE CHECK 
(OPTIONAL) 


SEE PROGRAMMING 
MODULE MANUAL 


WAVEFORM SEE 


PROGRAMMING 
MODULE MANUAL 


OBSERVATION 


Figure 4-1. Calibration 


4.3.1 POWER SUPPLY CALIBRATION 


Proper operation of your programming Pak depends on the 
programmer’s power supplies being properly adjusted. 
Therefore, the programmer power supplies must be 
calibrated first. 


Table 4-1 lists the voltage ranges for the power supplies. 
Test points for these supplies are located both on the 
controller board (see figure 4-2) and on the calibration 
extender. The power supply voltages can be measured in 
either location. 


Table 4-1. Calibration Voltage Ranges 


POWER | VOLTAGE RANGE TEST ADJUST 
SUPPLY | Min. Nom. Max. POINT 
5.08 TP1 R42 


+5V 5.11 5.15 

+24V 23.5 240 245 si 
+48 V 49.5 49.7 498 
+PROG V*} 480 490 5.11 
9V 9.20 -9.00 
5V 5.25 -6.00 


Below J7 


+12 V 


11.4 12.0 


* if adjustment is required, ground the right side of R59 on 
the Controller. Use R55 to adjust PROG V to +21.60 + 
0.20 V. 

** These test points are printed circuit feed-throughs to the 

left of J7. 


Required Equipment 


The following equipment is required for calibrating the 
29B's power supplies. 


¢ Digital Voltmeter 


¢ Non-conductive alignment tool, or 1/8” flat-blade 
screwdriver 


e Jumper wire approximately 12 inches long 


e IC removal tool or small screwdriver 


Set-Up 


The following procedures describe calibration set-up. Test 
points are shown in figure 4-2. 


1. Turn the programmer power off and remove the power 
cord. 


2. Remove the programming Pak (or module) from the 
programmer. 
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Figure 4-2. Power Supply Test and Adjustment Points 


3. Remove the protective shield from inside the 6. Turn the programmer power on. 
programmer. See subsection 4.2.2. 


> 


7. Measure the suppiies at tne test points shown in 
4. Connect your DVM to ground at TP2. See figure 4-2. figure 4-2. Results should be within the ranges listed in 


5. Ground TP3 by connecting a jumper from TP3 to TP2. table 4-1. 


4-3 
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Adjustment Procedures 


If all adjustments are within the specified range, no 
adjustment will be necessary. If the voltages fall outside 
the range, adjust them as follows. Adjustment points are 
shown in figure 4-2. 


1. Turn the programmer power off. See section 3.3. 
2. Unplug the power cord. See section 2.4. 


3. Remove any calibration equipment that has been 
installed. 


4. Remove the top cover (section 4.2.1). 


5. Remove the controller board protective shield 
(subsection 4.2.2). 


6. Remove the front panel assembly as shown in 
figure 4-3b. To do this: 


a. Remove the four screws from each corner of the 
panel. 
b. Remove center brace screw. 


7. Disconnect the front panel cable. 
8. Ground TP3 by connecting a jumper from TP3 to TP2. 


9. Connect power cord and apply power. 


CAUTION 
Extreme care is required to avoid 
short-circuiting discrete components 
while making measurements and 
adjustments. 
10. Adjust the supply (see figure 4-2 for potentiometer 
location) so that it corresponds to the correct voltage 
listed in table 4-1. If supply cannot be adjusted within 
the specified range, refer to subsection 4.4, 
Troubleshooting. 


4.3.2 THE PERFORMANCE CHECK/DC CALIBRATION 
SET-UP 


Some programming Pak manuals contain a “performance 
check” subsection in the calibration procedure. The set-up 
procedures below, are also the same procedures you would 
follow in setting up your programmer for calibration. Your 
programming Pak (or module) manual will contain complete 
details on how to do a performance check or set your 
programmer and Pak up for calibration. 


1. Turn the programmer power off. See subsection 3.3. 


2. Insert the appropriate calibration equipment into the 
29B. As an example, figure 4-4 shows the 29B set-up 
for calibration with a calibration extender and a Pak 
installed. 


4-4 


PROTECTIVE 
SHIELD 


(b) 


Figure 4-3. Front Panel and Protective Shield Removal 
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te PROGRAMMING - 
MODULE 


EXTENDER 


Figure 4-4. 29B with Programming Module Prepared for Calibration 


3. Turn the power back on. See subsection 3.2.2. 


CAUTION 
Remove all devices from the 
programming Pak (or module) before 
putting the 29B in the calibration 
mode. DC voltages applied to the 
socket during calibration will damage 
any device in the socket. 


4. Enter the calibration mode using select function C1. 
a. Press SELECT. 
b. Enter C1. 
c. Press START. 


5. 


4-5 
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The 29B is now ready for step 1 of the Measurement 
Chart in your Pak (or module) manual. Follow the steps 
in order. 


e To increment one step, press START. 
¢ To decrement steps, press REVIEW. 


After making a measurement, increment to the next 
step. 


. If any voltages fall outside the specified range, perform 


a complete DC calibration as outlined in your Pak (or 
module) manual. 


. TO exit the calibration mode, press COPY, VERIFY, or 


EDIT. 


<«—— CALIBRATION 


4.3.3 CALIBRATION OF PROGRAMMING PakS 
AND MODULES 


Data I/O manufactures two types of programming units to 
go with the 29B: programming Paks (which have expanded 
memory) and standard programming modules. Calibration 
of standard programming modules requires the Data I/O 
Universal Calibrator and Calibration Extender. Programming 
Paks have additional ROM (Read Only Memory), providing 
software which eliminates the need for the universal 
calibrator (the calibration extender is still necessary). 


This section contains two calibration procedures, one for 
programming Paks and one for standard programming 
modules. 


Calibration of Programming Paks 


The procedure for calibration of programming Paks is as 
follows: 


1. Measure and adjust the 29B’s power supplies as 
necessary. (See subsection 4.3.1). 


Enter the calibration mode: 


a. Press SELECT. 

b. Enter C1. 

c. Press START twice. The status display (see table 
4-2) will appear on the programmer display. 


3. Refer to section 4 of your programming Pak instruction 
manual. This section describes the equipment you will 
need for calibration. In addition, the measurement chart 
in this section contains calibration steps for your 
programming Pak. Step numbers on the programmer's 
display correspond to those on the Measurement Chart. 


¢ To increment one step, press START. To increment 
more than one step at a time, enter the desired step 
number and press START. 

© To decrement steps, press REVIEW. 


Perform the steps in sequence and make adjustments 
as necessary. 


4. For waveform observation, follow the directions in the 
programming Pak manual. Use select function A2 (see 
table 3-3) to fill RAM with the correct programming 
data. Consult the appropriate programming module for 
the proper RAM data. 


NOTE 
Always exit the calibration mode before 
inserting a programmable device. 


5. To exit the calibration mode, press COPY, VERIFY, or 
EDIT. 


Table 4-2. Displays and Instructions for Calibrating Standard Programming Modules 


CORRESPONDING 


DISPLAY INSTRUCTION 


HEX ADDR 0000 


SET START HI 
(or SET START LOW) 


Set the programmer in STOP. 


Set the programmer in START. 


OPERATOR ACTION 


Enter a 4-digit hexadecimal address, 
then press START. 


Press SELECT until SET START HIGH 
appears and then press START. 


Press SELECT until SET START LOW appears 


(status display) 
0000 DFF R00 L F 


Monitor the Start/Stop Line. 


and then press START. 


PGM ONE ADDR Initiates waveform tests. 


Select the status display and note the 
appropriate values. 


Ld bd Lt Gb 
% gm 22% Confirm data on the DO bus. Select the status display and note the 
X o4s : 
@ 2 %, < S. appropriate values. 
Og ee 
@ 
@ 7 -8 Load data onto the DI bus. Select the status display, enter the desired 
oo S} %% data, and press START. 
e 3, S. “C. 
se ff Q; 3, Set the programmer in Reverse. Select the status display and press 
Cm BACKSPACE. 
a 2 
Zn Set the programmer in Forward. Select the status display and press START. 
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Calibration of Standard Programming Modules 


Calibration of standard programming modules (see 


table 4-2) is performed as follows: 


1. Measure and adjust the programmer power supplies as 


Siew i teas dOns a:tbeweetn AA aN 
MeCessdly. oct SUDSCULIOT! 4.0.1.) 

2. Put the programmer into the calibration mode via Select 
Function C1. 


a. Press SELECT. 

b. Enter C1. 

c. Press START twice. The status display (see 
table 4-2) will appear on the programmer display. 


NOTE 
Some modules do not allow increment or 
decrement from certain steps. 


NOTE 
Some programming modules generate 
waveforms only in automatic program 
mode. PGM ONE ADDR Js a manual 
program mode and will not cause such 
programming modules to output 
waveforms. For these modules, use the 
program command instead. To determine 
is a programming module can be used 
only in autematic mode, see Section 3 of 
the programming module operation and 
maintenance manual. 


3. Refer to the instruction manual for the programming 
module. Section 4 contains required equipment, 
calibration instructions, and the calibration charts. To 
enter step 1, press START. To enter any other step, 
enter the desired step number and press START. To 
increment one step, press START. To decrement steps, 
press REVIEW. The programmer displays and 
calibration chart instructions are given in table 4-2. 


4. To exit calibration, press COPY, VERIFY, or EDIT. 


4.4 TROUBLESHOOTING 


The following troubleshooting information is an aid to 
understanding malfunctions and locating hardware failures. 
Subsection 4.4.1 discusses the procedures for establishing 
the type of trouble occurring in the unit and the steps 
necessary for further servicing. Subsection 4.4.2 directs the 
service technician to the portion of the circuitry suspected 
of failure. These procedures do not isolate the fault to the 
component level, but the information in this section, along 
with normal troubleshooting and service techniques, should 
lead to the solution of most hardware failures. 


Circuit descriptions are provided in Section 5, and 
Schematics are iocated in Appendix F. 
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4.4.1 PRELIMINARY TROUBLESHOOTING 


The following paragraphs describe some common 


vu paper 


problems, with corrective steps following each. After 
performing each step, determine whether the problem still 
exists. Figure 4-5 shows the overall troubleshooting 
procedure. 


DOES 
PROGRAMMER 
POWER COME ON 
? 


GO TO 
SECTION 4.4.1 


DOES 
SERIAL INTERFACE 
WORK PROPERLY 


GO TO 
SECTION 4.4.1 


DOES 
PROBLEM STILL 
EXIST 


TROUBLESHOOT 
SPECIFIC AREA 
(SECTION 4.4.2) 


CALIBRATE 
EQUIPMENT 


Figure 4-5. Troubleshooting 


Erratic or Nonfunctional Programmer 


If the programmer does not operate, or operates erratically, 
check the following: 


1. Check that the AC power cord is firmly plugged in and 
the power switch is on. 


2. Check that AC power selection is the same as the line 
voltage. The voltage at which the programmer will 
operate is shown on the voltage selector wheel. For 
proper operation, the line voltage must be within 
+5/-—10 percent of the voltage shown on the wheel. 
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3. Check that the programming module is fully seated in 
the mating connector (J7) of the controller card. During 
operations with the programming module removed, TP3 
must be grounded by a jumper to TP2. 


4. Remove any cables attached to the serial interface. 


5. Check the power supplies according to the calibration 
procedure in paragraph 4.2. If this reveals a problem, - 
refer to ‘‘power supplies” paragraph 4.4.2. 


6. Check the installation of all hardware. Check the 
orientation and connection of all cables as well as the 
seating of the PC boards. Check all jumpers. 


7. Check the controller as described in paragraph 4.4.2. 

8. If steps 1 through 7 do not reveal the problem, contact 
your Data 1/O Service Center. 

Serial I/O Failures 


If the serial interface does not work properly, check the 
following: 


1. Make sure the programmer and other equipment to 
which it is connected are set for the same parity, baud 
rate, and number of stop bits. 


2. Check the operation of the peripheral equipment 
according to the manufacturer's procedures. 


3. Troubleshoot the serial interface circuitry as described in 
paragraph 4.4.2. 
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4.4.2 TROUBLESHOOTING SPECIFIC AREAS 


The following paragraphs discuss specific areas of circuitry. 
After performing each step, determine whether the problem 
continues. 


Power Supplies 


If it has been determined from preliminary troubleshooting 
that a problem exists in the power supplies, do the 
following: 


1. Turn the programmer off for 30 seconds and then on 
again. Portions of the power supply employ foldback 
overcurrent protection. If a supply becomes overloaded, 
it will remain off even after the overload is eliminated. 
The protection circuits can be reset by turning the 
programmer off for 30 seconds and then on again. 


2. Refer to table 4-3 to check the voltage for each power 
supply circuit. Test points are shown in figure 4-2. 


3. To replace any components associated with the +5 V, 
—5V, or +12V supplies, first remove jumpers JP1 
through JP5 to protect other circuits from overvoltage. 
When component replacement is complete, reinsert the 
jumpers and calibrate the programmer per section 4.3.1. 


Table 4-3. Power Supply Voltages 
VOLTAGES ~ 


PIN ON 
CALIBRATOR 
OR EXTENDER 


SUPPLY 


Min. Nom. Max. 


5.08 
23.5 
49.5 

—9.20 
—5.25 

4.80 

11.4 


5.11 
24.0 
49.7 

—9.00 
—5.00 

4.90 

12.0 


5.15 
24.5 
49.8 

— 8.80 
-4,75 

5.11 

12.6 


+PROG V* 
+12T 


* A programming module must be installed or TP3 must 
be grounded. 

t To replace faulty components associated with this 
supply, first remove jumpers JP1 through JP. After 
bringing the supply into range, replace the jumpers and 
calibrate the programmer. 
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Centroller 


If it has been determined from preliminary troubleshooting 
that a problem exists in the controller, do the following: 


1. 


Check that all socketed devices are seated firmly and ail 
soldered components are intact. Check that jumpers JP1 
through JP5 are installed. 


. With an oscilloscope, detemine if the Ve02 timing signal 


is present by observing pin 7 of U5 on the controller 
board. if it is not present, check that the programming 
module is grounding pin HH (TP3) on J7 (the 
programming module interface). 


If steps 1 and 2 do not reveal the problem, contact your 
Data 1/O Service Center. 


Serial Interface Circuitry 


If it has been determined from preliminary troubleshooting 
that a problem exists in the serial interface, do the 
foiiowing: 


1. 


Use an oscilloscope to observe the signal on pin 3 of 
U14 on the controller card. The frequency cf the signal 
at pin 3 should be 16 times the selected baud rate. 
(Baud rate = [1/time] divided by 16.) 


. Perform steps a through d. A failure in any step 


indicates a failure in the ACIA (U14) or the drivers U9 or 
U10). 


a. Initiate a copy from the data RAM to the 
serial port. 

b, Check the voltages at U14, nins 23 and 24. Both 
should read 0.0 to 0.5 V. 

c. Press START. 

d. Use the oscilloscope to observe pin 2 of the serial 
interface. The 29B should be transmitting data at the 
selected baud rate. Perform the following procedure 
(see figure 4-6). 


(1) Turn 29B power on. 

(2) Set baud rate to 9600. 

(3) Using select function A2, enter 00 hex data into 
all of RAM. 

(4) Connect oscilloscope probe to pin 2 of serial port 
connector J3. 

(5) Copy RAM to port using 0 (default) values for 
beginning addresses and maximum (default) block 
size. 

(6) Observe the waveform. It should be similar to 
figure 4-6(b). 

(7) Using select function A2, enter FF hex data. 

(8) Repeat steps (4) and (5) above. 

(9) Observe waveform. It should be similar to 
figure 4-6(a). 
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Figure 4-6. Checking Baud Rate on Pin 2 
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SECTION 5 
CIRCUIT DESCRIPTION 


5.1 INTRODUCTION 


This section describes the 29B Universal Programmer's 
circuitry. It includes both a general and detailed description 
and of the programmer's main circuitry functions. Each 
detailed circuitry function is described in its own subsection 
aiong with a biock diagram. 


This section also discusses the main components of the 
29B programmer, address map assigments, and assembly 
cabling. 


5.2 GENERAL CIRCUIT DESCRIPTION 


The 29B is a microprocessor-based programmer utilizing 
bus-style architecture. Figure 5-1 shows the functional 
blocks of each of the circuits in the 29B. These circuits are 
described in the following paragraphs. 


AC line voltage passes through a voltage selector and filter 
to the transformer and a cooling fan. The AC is rectified, 
filtered and regulated for use by all other circuits on the 
29B. 


A microprocessor unit (MPU) controls all operations for the 
29B. MPU circuits are interfaced to a keyboard and display. 
An RS232 serial port is standard. 


The actuai programming of devices is performed through a 
64-pin connector (J7)which interfaces with programming 
modules or Paks. Optionally, devices can be programmed 
by a PROM Handler through a special hardware interface 


provided for this purpose. 


The internal RAM of the 29B provides storage for all 
programming data information whether from a master 
device or from an external source (computer, terminal, 
etc.). 


5.3 DETAILED CIRCUIT DESCRIPTION 


Figure 5-2 shows an interconnect diagram of the 29B. Each 
of the circuit areas, power supplies, MPU, 
keyboard/display, RAM, and interface circuits, are 
described in the following paragraphs and shown in 
separate block diagrams. 


Figure 5-2 also shows the cabling between assemblies 
along with associated connector cables and part numbers. 
The schematic for each board is located in Appendix F. 


The component layout of the 298 is shown in figure 6-3. 


A.C. 
LINE POWER 
SUPPLY 


CONTROLLER 


— KEYBOARD/DISPLAY 


INTERFACE TO 


HANDLER 
(OPTION) 


EXPANSION 
RAM 


ee 


RS232 SERIAL I/O 


INTERFACE TO 


PROGRAMMING MODULE 


OR PAK 


Figure 5-1. Functional Diagram of 29B Universal Programmer 
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DISPLAY, 
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EXPANSION RAM 
BOARD 


CONTROLLER BOARD 


FILTER 
BOARD 


HANDLER 
INTERFACE 
CONNECTOR 


SERIAL 1/0 
INTERFACE 
CONNECTOR 


STATUS SWITCH ASSEMBLY 


Figure 5-3. Circuit Board Locations 


5.3.1 POWER SUPPLIES 


Figure 5-4 is a block diagram of the power supply circuitry. 


Voltage Selector/Filter 


The voltage selector/filter unit provides circuit protection, 
filtering and provides the ability to tap different voltages 
from the transformer. 


Transformer 


The power transformer has multiple primary windings to 
allow the use of various input line voltages. The secondary 
develops appropriate voltages for the rectifiers and filters. 


Filter Board 


Four rectifier and capacitor filter networks on the filter 
board provide the dc voltages for the various regulators. 
PNP transistors Q1 and Q2 turn off to isolate +40 and 
+HV on high voltage shutdown, 


ey? 


5-3 


Voltage Regulator 


The voltage regulator circuits are located on the controller 
printed circuit board. 


The +5-volt regulator consists of a TL430 shunt regulator 
(VR3) driving an MJE 240 (018) which in turn drives two 
TIP 35A pass transistors (013 and Q14). Feedback is 
provided to the TL430 by R42, the voltage adjusting 
potentiometer. Foldback current limiting is achieved by 
sensing both output current and output voltage. If an 
overcurrent exists, 15 senses the increased voltage across 
R32 and reduces the base drive to the pass transistor, 
which drops the output voltage. When the output voltage 
goes below the CR18 Zener diode reference, the base 
current flows through CR19 to Q15, further dropping the 
output voltage. To reset the regulator from its foldback 
condition, input power must be removed long enough to 
discharge C37. If an over-voltage condition exists, CR20 


will begin to conduct, causing 016 to pull base current 
from O18. 


The 24-volt supply and the 48-volt supply work on the 
same principle as the 5-volt supply. The difference is that a 
current source, rather than an emitter follower, is used to 
supply base current to the pass transistors. 
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FILTER 
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REGULATOR 


VR2, R23, 08 
24V REGULATOR 


J3 (SERIAL 1/0) 


+5V -5V +24V 
CONTROLLER BOARD (PARTIAL SHOWN) 701-0047 


The programmable supply (++ PROG) uses a Darlington 
differential pair, 024-025 and 022-023, working into a 


current source, Q21. Pass transistor 019 foiiows tne 
TLA3Z0 si hunt reaulator {VR4) 


Ulle 1SOyuM 


ome rrltn nn 


current source vortage. AT 
provides a 5V reference for the plus input of the differential 


pair (024). Two feedback nodes are connected to the 


sense and and onerate lines. By connecting various 
resistors to these lines, the output voltage can be 
“programmed” to any level between 5V and 40V. Foldback 
current limiting is provided in the same manner as in the 
+5V supply. The +12V, -9V, and -5V supplies use 
standard monolithic regulators. 


The shutdown control signals the card to turn off +HV 
and +40V unregulated supplies when a programming 
module is removed. This in turn shuts down the +48V, 
+24V, +PROG and +/70V supplies. 


Fuses F1 through F7 on the filter board, in conjunction 
with the crowbar zeners on all supply outputs, protect the 
system electronics from an overcurrent condition on the 
supply lines. An overvoltage condition could occur from 
failure of power supply components. 


5.3.2 KEYBOARD/DISPLAY 


The keyboard/display consists of a hex keyboard, four 
mode keys, three source/destination keys, REVIEW key, 
START key and a 16-character, 14-segment display. See 
fiqure 5-5. 


Display operation starts with four scan lines, RSO-RS3, 
from the keyboard interface IC on the controller. These 
scan lines continuously count in binary and are sent to the 
display driver board for decoding. Two demultiplexers (U3 
and U4) decode the scan lines for use by the display grid 
drivers (U1 and U2). Data (six bits) associated with each 
scan count passes to a character generator PROM (U11) 
whose four-bit output is demultiplexed into 16 lines by a 
decoder (U12) and four quad flip-flops (U7 through U10). 
These outputs are used by the display anode drivers (U5 
and U6). 


Keyboard operation starts with three continously counting 
scan lines from the controller which are demultiplexed and 


The bus consists of a 16-bit address bus, 8-bit data bus, 
power supply lines, and severai controi iines. Aji 
communications between portions of the circuitry are 
handled in the same manner over this bus. The timing of a 
write cycle is shown in-figure 5-7, and the timing of a read 
cycie is shown in figure 5-8. 


The buffered bus is availabie at the programming 
pak/module interface (J7). 


Table 5-1 is the address map of the controller and shows 
the location, in hexadecimal, of each decoded function of 
the controller. 


Table 5-1. Address Map 


ADDRESS RANGE FUNCTION 


0000-07 FF 


Internal Scratch RAM (Controller 
U18,19,29,30) 


used to scan the keyboard. When a key is pressed, the 
signal passes back to the controller on one of the five 
return lines. 


5.3.3 CONTROLLER 


The controller PCB is shown in block diagram form in 
Figure 5-6. Each block will be discussed in this section. 


The microprocessor drives the bus through the address 


buffers and data buffer. Control! signals are also generated 
by the processor and sent through the buffers to the bus. 


E400-E7FF Future Scratch RAM 
0800-OF FF Future Program pian (% U38) 
{000-1 FFF Program Memory (U 
2000-5FFF Data Ram (16K pages from 
dynamic RAM board) 
6000-9FFF Expanded memory from 
programming modules 
| A000-DFFF Program Memory (U33-U36) 
E000-EOFF Interface Control Register (U31) 
E100-E1FF I/O Status Switches (U52) 
E200-E3FF I/O Area: 
E200 High Order Address Register 
(U51) 
E201 Low Order Address Register 
(U42) 
E202 Data Gate/Data Register (U44,47) 
E203 Status Register/Status Gate 
(U45,46) 
E204/E205 Kbd/Display Interface (U20) 
E206/E207 Serial E/O (U14) 
E208-E2FF Not to be Used (Overwrites 
E200-E207) 
E300/E301 Dynamic RAM Board - Bank & 
Page Register 
E302-E3FF Unassigned 
E800-EFFF Future Program Memory (% U38) 
FO00-FFFF Program Memory (U37) 
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The decode PROMs provide selection of the various gates, 
registers and other devices connected to the data bus. 
Refer to the memory map of table 5-1. Ve@2 is connected 
to the chip select of each decode PROM to provide the 
correct timing for writing to registers or reading gates or 
memory. R/W is used for EPROM timing. 


The programming module interface is provided by address . 
registers, status gates, data register, data gates and control 
register. 


When a programming module is removed, the 
microprocessor is held reset by a high on the line HH of 
J7. When the programming module is installed, line HH of 
J7 is grounded, removing the reset after a short delay. This 
feature allows programming modules to be changed with 
the power on in order to preserve RAM data. 


Additional flexibility of the programming module interface 
can be gained with software control of the interface control 
register. The programming module interface can be set up 
so that the microprocessor bus is buffered and directly 
available at the port. This is accomplished by disabling the 
address register outputs, enabling the address gates in the 
outward direction, and connecting the data gate directly to 


1 J1 


U22 
ADDRESS 
DECODER 

U17 

PAGE 


REGISTER 


the R/W line. The data gate is enabled at the appropriate 
address by decoding done externally to the port over the 
Data Gate Enable line. 


The serial interface is controlled by a 6850 Asynchronous 
Communications Interface Adapter (ACIA, U14) and 
appropriate software. The timing signal for the ACIA is 
provided by the baud rate generator U7. The baud rate is 
selected by rate select switch U8. The status switch 
provides for selecting parity and stop bits. The ACIA 
occupies two addresses (table 5-1) and uses !RQ to 


interface with the microprocessor. 


The on-board program memory occupies ups to 28K bytes 
of PROM U32-U38 decoded in 4K segments. 


Temporary data storage on the controller board consists of 
2K bytes of RAM (U17, U28) decoded in 1K segments. 


Expansion RAM Board 


The Expansion RAM Board (figure 5-9) allows the 
expansion of the base unit memory by up to 64K bytes. 
The RAM is in 16K byte banks with four banks per page. 
Future expansion of the board RAM will permit 128K of 
memory. 


U24 
REFRESH 
COUNTER 


EXPANSION RAM BOARD 


Figure 5-9. Expansion RAM Board Block Diagram 
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Timing is generated using system timing in conjunction 
with a tapped digital delay line (U20), with a PAL (U21) as 
the combinational logic. 


Address decoding is performed by PAL U22. U17 serves as 
the bank and page register, with D6 and D7 at address 
E300 controlling the bank select, and DO at address E301 
controlling the page select. 


Address multiplexing is accomplished via U23, U26, U27 
and U28. Multiplex timing is generated by the delay 
line/PAL timing generator. 


The board uses invisible refresh for the RAMs. During the 
first half of each ‘E’ cycle, the RAMs are refreshed. 
Refresh timing is generated by the delay line/PAL timing 
generator. The refresh address is generated by U24. 


U1 
DECODER 


64K or 128K (future) configuration is selected by the 
programming of PAL, U22. 


The D-RAM array is addressed at 2000 through 5FFF, 
hexidecimal. 


Handler Interface Board (Optional) 


The handler interface board (Figure 5-10) is comprised of a 
3-to-8 decoder (U1) which receives binning information 
from the controller register U31 and ouputs this information 
to the handler interface connector at the back panel of the 
29B. Also at this interface a strobe signal is used to notify 
the handler when the binning information is stable. 


Only one of four possible binning signals are sent at any 
one time: pass bin, illegal bit bin, program error bin, or 
verify error bin. 


PASS BIN 
ILLEGAL BIN 
PROGRAMMING ERROR BIN 
VERIFY ERROR BIN 
STROBE 


OPTIONAL HANDLER INTERFACE 


Figure 5-10. Optional Handler Interface, Block Diagram 
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DATA TRA 


A.1 INTRODUCTION 


This appendix defines the data translation formats available 
for the 29B. The 29B is capable of interfacing with all 


RS232C serial equipment employing a data translation 
format described in this appendix. 


Each data translation format is assigned a 2-digit code 
which the operator enters into the programmer (from the 
keyboard or, in remote control, through the serial port) to 
send or receive data in that format. In addition to the data 
translation format code, there is a 1-digit instrument 
control code which specifies control characters to be 
transmitted to, or received from, peripheral instruments. 


In several cases, the 29B’s standard display symbols will be 
shortened to accommodate large address fields used with 
some translation formats. These are: 


e Copy Ram to Port 
FORMAT: HP 64000 Absolute (Format #89) 
DISPLAY: RAM> PORvZZZZZZZZ 

O% 
3 


ar 


Copy RAM to Port 


FORMAT: Motoroia Exormax (Format #87) 
DISPLAY: RAM> PORvVZZZZZZ 
Oy 
4% 
» @ 
S 


Copy Port to RAM 
FORMAT: HP 64000 Absolute (Format #89) 
DISPLAY: POvZZZZZZZZ/YYYY 


A-1 


AT 


ON FORMATS 


e Copy Port to RAM 
FORMAT: Motorola Exormax (Format #87) 


Pressing REVIEW to review I/O parameters. 
FORMAT: HP 64000 Absolute* and Motorola Exormax 
DISPLAY: XXXX/YYYY> ZZZZZZ 


Po BoD Oy 
Zo 8S 4% 
23 *% 8% 

% 


A.2 DATA VERIFICATION 


For data verification the 29B calculates a sum-check of all 
data sent to or from the programmer. At the end of a 
successful input operation, the programmer will display the 
sum-check of all data transferred. It will also compare any 
received sum-check fields with its own calculation. If the 
two agree, the programmer wiii dispiay the sum-check; a 
mismatch will produce an error message. Output data is 
always followed by a sum-check field which may be printed 
on disk or tape for use in subsequent input operations. 


* In the HP format, ZZZZ7Z represents the six least significant 
digits in the 8-digit address field. if either of the two most 
significant digits in the field is not zero, the display will show 
PORT instead of the address. To view the address, reinitiate the 
key sequence for the input or output operation. 
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A.3 CODES 


Each format is assigned a 2-digit data translation format 
code which the operator enters to instruct the programmer 
as to which format to use. In addition to this code, a 
1-digit instrument control code may be used to specify 
control characters for peripheral equipment. The codes 
must be formatted as shown in figure A-1. If no codes are 
entered into the programmer, the current default values will 
be in effect. 


Figure A-1. Formatting the Instrument Control Code 
and Data Translation Format Code 


See table A-1 for a definition of instrument control codes 
and table A-2 for a definition of data translation format 
codes. 


Table A-1. Instrument Control Codes 


CONTROL 


CODE PROGRAMMER ACTION 


Sends data immediately and continuously 
until acknowledging a “‘reader off’’ code. It 
will then stop sending data until receiving a 
“reader on’’ code. Sending no control 
codes results in normal, uninterrupted 
transmission. 


Sends “reader on” (ASCII DC1/Hex 11) 
when ready to receive data, and “reader off” 
(ASCII DC3/Hex 13) when all data is 
received. Also send “punch on” (ASCII 
DC2/Hex 12) before sending data, and 
“punch off” (ASCII DC4/Hex 14) after 
sending data. 


Sends data after acknowledging a “reader 
on” (ASCII DC1/Hex 11), and stops sending 
data after acknowledging a “reader off’ 
ASCII DC3/Hex 13). 


Table A-2. Data Translation Formats 


FORMAT CODE 


Binary 10 
DEC Binary 11 
ASCII-BNPF 01 (05)* 


ASCII-BHLF 
ASCII-B10F 


02 (06)* 
03 (07)* 


5-Level BNPF 08 (09)* 
Spectrum 12 (13)* 
ASCIll-Octal (Space) 30 (35) + 


ASCIll-Octal (Percent) 31 (36) + 
ASCIll-Octal (Apostrophe) 32 
ASCIl-Octal SMS 37 
ASCIll-Hex (Space) 50 (55) + 


ASCIll-Hex (Percent) 51 (56) + 
ASCIl-Hex (Apostrophe) 52 
ASCli-Hex SMS 57 
ASCIl-Hex (Comma) 53 (58) + 


RCA Cosmac 70 
Fairchild Fairbug 80 
MOS Technology 81 
Motorola Exorciser 


Intel Intellec 8/MDS 
Signetics Absolute Object 85 
Tektronix Hexadecimal 86 
Motorola Exormax 


Intel MCS-86 Hexadecimal Object 
Hewlett-Packard 64000 Absolute 89 
Texas Instruments SDSMAC 


* For transmission of data without start codes, these 
alternate data translation fromat codes are used. 

+ For transmission of data with the SOH (CTRL A) start 

code, these alternate data translation format codes 

are used. 
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A.4 LEADER AND NULL OUTPUT 


A ieader is a string of characters that is attached to the 


data fila It ie 11ead ta eanarata 


beginning and end of a data file. It is used to separate 


begi 
different files from one another and allows extra room 
which may be necessary for loading and unioading the data 
medium to or from equipment. For the 29B, the leader is 
sent at the beginning and end of a data output operation. 
With one exception, this leader will always be comprised of 
carriage return [CR], a line feed [LF], and 50 nulls in 
succession. 


Null count is the number of null characters in a string of 
characters between each record or line within a file. What 
actually comprises a data record depends upon the format 
that is being used. Records and lines can basically be 
thought of as separations of data within a file. 


Null count is a parameter which can be defined by the 29B 
user for use with printers with a slow carriage return 
response time. The number of nulls can be set to any 
value from zero to 254 decimal (FE hexadecimal). With one 
exception, the string of characters actually sent between 
each and every record or line of the fiie includes a carriage 
return [CR], a line feed [LF], and the number of nulls 
defined by the null count. 


The exception referred to above for the leader and the null 
count occurs when the user defines the null count equal to 
the value of “FF” hexadecimal (or 255 decimal). in this 
case, the leader is made up of solitary carriage return (no 
line feed and no nulls). Also, the string separating the 
records of the file is a carriage return (no line feeds and no 
nulls). 


Parity for the beginning and end leader is the same as the 
parity for the data within the file. The same is true for the 
carriage return [CR], line feed [LF] and nulls separating the 
records or lines of the file. They have the same parity as 
the data. However, it should be noted that binary formats 
(10, 11 and 89) do not have parity for their data; therefore, 
the leader, the carriage return, line feed, and nulls 
separating the records for these files have no parity. 


A.5 TRANSLATION FORMATS 


This section gives information on the translation formats 
available for input and output by the 29B. 


A.5.1 BINARY TRANSFER, CODE 10 


Data transfer in the Binary format consists of a stream of 
8-bit data words preceded by a byte count and followed by 
a sum-check. The Binary format does not have addresses. 


A paper tape generated by a programmer will contain a 
5-byte, arrow-shaped header followed by a null and a 
4-nibble byte count. The start code, an 8-bit rubout, 
nulls and a 2-byte sum-check of the data field. Refer to 
figure A-2. 


A-3 


ee | 2 BYTE HEX SUM-CHECK (02FB) 
"| 2 NuLLS 


eeoevee 


@eeeeeoteoevoeonedveenveeooet 


>| 
8 BIT 


e e 
@©0000+8e08 Bees (START CODE) 
2& - 


ai NIBBLE HEX BYTE COUNT 


0020 HEX 
(32 DECIMAL) 


HI 
ORDER 


LOW 
ORDER 


x 5 
my 
PO 
Ss 
(eee a 
aN 
OPo 


Figure A-2. Input or Output Binary Tape 


The programmer stores incoming binary data upon receipt 
of the start character. Data is stored in RAM starting at 
the first RAM address and ending at the last incoming data 
byte. Transmission may be aborted by pressing any mode 
key. 


A.5.2 DEC BINARY FORMAT, CODE 11 


Data transmission in the DEC Binary format is a stream of 
8-bit data words with no control characters except the start 
code. The start code is one null preceded by at least one 
rubout. A tape output from the programmer will contain 32 
rubouts in the leader. The DEC Binary format does not 
have addresses. 
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A.5.3 ASCII BINARY FORMAT, CODES 01, 02 AND 03 
(OR 05, 06, AND 07) 


In these formats, bytes are recorded in ASCII codes with 
binary digits represented by N’s and P’s, L's and H’s, or 
1's and 0’s, respectively. See figure A-3. The ASCII Binary 
formats do not have addresses. 


ASCII-BNPF, Format Code 01 (or 05) 


°23BPNPNPNPNF BPNPNPNPNF BPNPNPNPNF BPNPNPNPNF:: 
3 
ASCII-BHLF, Format Code 02 (or 06) 
“SBHLHLHLHLF BHLHLHLHLF BHLHLHLHLF BHLHLHLHLF«: 
1 2 3 
ASCII-B19F, Format Code 03 (or 07) 


":B10101010F B10101019F B10101019F B10101010F<: 


\y 2 3 


NOTES 


. Start code is a nonprintable STX — CTRL B (start 
code is optional). 

. Characters such as spaces, carriage returns and line 
feeds may appear between bytes. 

. End code is a nonprintable ETX — CTRL C. 

. Data can also be expressed in 4-bit words 


Figure A-3. ASC11 Binary Formats 


Figure A-3 shows four data bytes coded in each of the 
three ASCII Binary formats. Incoming bytes are stored in 
RAM sequentially starting at the first RAM address. Bytes 
are sandwiched between ‘‘B” and ‘‘F’’ characters and are 
normally separated by spaces. Data can also be expressed 
in 4-bit words. Any other characters, such as carriage 
returns or line feeds, may be inserted between an “‘F’” and 
the next ‘’B’’. The start codes are a nonprintable STX, 
control B (or hex 02), and the end code is a nonprintable 
ETX, contro! C (or a hex 03). 


NOTE 
Data without a start code may be input 
to or output from the programmer by use 
of alternate data translation format 
codes. These are: ASCII-BNPF, 05; 
ASCII-BHLF, 06; ASCII-B10F, 07. 


A single data byte can be aborted if the programmer 
receives an E character between B and F characters. Data 
will continue to be stored in sequential RAM addresses. 
The entire data transfer can be aborted by pressing any 
mode key (COPY, VERIFY, SELECT, EDIT). 


Data is output in 4-byte lines with a space between bytes. 
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A.5.4 THE 5-LEVEL BNPF FORMAT, CODES 08 OR 09 


Except for the start and end codes, the same character set 
and specifications are used for the ASCII-BNPF and 5-level 
BNPF formats. 


Data for input to the programmer is punched on 5-hole 
Telex paper tapes to be read by an ASCll-based reader 
that has an adjustable tape guide. The reader reads the 
tape as it would an 8-level tape, recording the 5 holes that 
are on the tape as 5 bits of data. The 3 most significant 
bits are recorded as if they were holes on an 8-level tape. 
The programmer's software converts the resulting 8-bit 
codes into valid data for entry in RAM. 


The start code for the format is a left parenthesis, (‘Figs 
K” on a Telex machine), and the end code is a right 
parenthesis, (‘Figs L’’ on a Telex machine). The 5-level 
BNPF format does not have addresses. 


NOTE 
Data without a start code may be input 
to or output from the programmer by use 
of the alternate data translation format 
code, 09. 


A.5.5 SPECTRUM FORMAT, CODES 12 OR 13 


In this format, bytes are recorded in ASCII codes with 
binary digits represented by 1's and 0's. Each byte is 
preceded by an address. 


Figure A-4 shows 2 data bytes coded in the Spectrum 
format. Bytes are sandwiched between the space and 
carriage-return characters and are normally separated by 
line feeds. The start code is a nonprintable STX, control B 
(or hex 02), and the end code is a nonprintable ETX, 
control C (or hex 03). 


NOTE 
Data without a start code may be input 
to or output from the programmer by use 
of the alternate data translation format 
code, 13. 


2 
CHUCRULF) AAAA(SP)10101010 (CR)(LF) AAAA(SP)10191018 (CRLF): 


, nn, cee aes 


1 4 


NOTES 


1. Start code is a nonprintable STX (start code is optional). 

2. Address code is 4 decimal digits. 

3. 4 or 8 data bits appear between space and carriage 
return. 

4. End code is a nonprintable ETX. 


Figure A-4. Spectrum Format 


10-990-0013 


A single data byte can be aborted if the programmer 
receives an ‘’E”’ character between a space and a carriage 
return. Data will continue to be stored in sequential RAM 


illustrates 4 data bytes coded in each of the 9 ASCII-Octal 
and Hex formats. Data in these formats is organized in 
sequential bytes separated by the execute character (space, 


addresses. The entire data transfer can be aborted by 


pressing any mode key (COPY, VERIFY, SELECT or EDIT). 


Data output to a printer will have one address and one 
byte of data on each line. The programmer first sends an 
STX (optionally), then the data, and finally an ETX. 


A.5.6 ASCII OCTAL AND HEX FORMATS, 
CODES 30-37 AND 50-58 


Each of these formats has a start and end code, and 
similar address and sum-check specifications. Figure A-5 


ASCIl-Octal (Space), Format Code 30 (or 35) 


2 


1 > <sa0000007 


percent, aposirophe, or comma). Characters immediately 
biesedng the execute character are interpreted as data. 


Limes me 


avnrace QGhit cinta Aw 


al 
ASCil-Hex and Octal formats can SXpress G-oit Gata, CY 2 


or 3 octal, or 1 or 2 he 


characters. Line feeds, carriage 


returns and other ja ee may be included in the data 
stream as long as a data byte directly precedes each 
execute character. 


ASCIl-Hex (Space), Format Code 50 (or 55) 
2 


KD sa0e00 


252 252 252 252:.; 


PAS 


ASCIll-Octal (Percent), Format Code 31 (or 36) 
2 


1 > 50090000) 


3 4 
ASCH-Octal [Apostronphe), Format Code 32 
2 


1 -><3a900000) 


252'252'252'252'<": 


ASCII-Octal SMS, Format Code 37 
2 


> $000000,) 
252'252'252'252’ 


3 7 


NOTES: 


1. Start code is nonprintable STX — CTRL B 
(optionally SOH — CTRL A). 


2. Optional address code may precede any data byte. 
Up to six address digits in octal formats, four in 


hex followed by a comma (except ASCII Hex 
Comma Format which is followed by a period). 


Soe 


AA AA AA SK 
3 4 
ASCIl-Hex (Percent), Format Code 51 (or 56) 
2 


1 —»cisaceoe! 


AA%VAAKAAWAAKT 
a 
3 


4 


ASCll-Hex (Apostrophe), Format Code 52 
2 


11> $0000” 
AA'AA’AA'AA'S: 


4 
ASCIl-Hex SMS, Format Code 57 
2 


6 > enoo00! 


ek Roe 
7 
ASCIl-Hex (Comma), Format Code 53 (or 58) 
2 


1—> 72: $0000 } 


AA,AA,AA,AA,. 


SEN 


3 4 


. Execute code. 


End code is a nonprintable ETX — CTRL C. 
Data can also be expressed in 4-bit form. 

Start code is nonprintable SOM — CTRL R. 
End code is a nonprintable EOM — CTRL T. 


Figure A-5. ASCII-Octal and Hex Formats 
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Although each data byte has an address, most are implied. 
Data bytes are addressed sequentially unless an explicit 
address is included in the data stream. This address is 
preceded by a “’$”’ and an “‘A’”’, must contain 2 to 4 hex or 
3 to 6 octal characters, and must be followed by a comma, 
except for the ASCII-Hex (Comma) format, which uses a 
period. The programmer skips to the new address to store 
the next data byte; succeeding bytes are again stored 
sequentially. See figure A-6. 


HEX 
ADDRESS 


OCTAL 
ADDRESS 


ADDRESS a 
FIELD 1 SAHHHH, ; 


OR 


$A123456 , 


Pee we ee et agtTe 


Data byte that follows address 
field is input to RAM address 
defined in address field. 


NOTES: 


H =hex character. 1,2,3,4,5, and 6= octal characters. 
Address has 2-4 or 3-6 octal characters. The programmer 
assumes leading zeros. 

Address must be preceded by ‘‘$A” and followed by ”’,”’. 
Line feed and carriage return optional. 

The most significant octal digit may be @ or 1 when 
expressing 16 bits as 6 octal characters. 


Figure A-6. Optional Address Field in ASCII-Octal and 
Hex Formats 


Each format has an end code, which terminates input 
operations. However, if a new start code follows within 16 
characters of an end code, input will continue 
uninterrupted. 


A-6 


After receiving the final end code following an input 
Operation, the programmer calculates a sum-check of all 
incoming data. Optionally, a sum-check can also be 
entered in the input data stream. The programmer 
compares this sum-check with its own calculated sum- 
check. If they match, the programmer. will display the sum- 
check; if not, a sum-check error will be displayed. 
Specifications for the optional sum-check are given in 
figure A-7. 


Hex 


End of Hex Dat 
Soa Sum-Check 


-—_1—__, 


... HH HH HH 


$SHHHH, 


[ end code ] 


Octal 
Sum-Check 


—— 


$3 123456 


End of Octal Data 


235 235 {end code} 


NOTES: 


Sum-check field consists of 2-4 hex or 3-6 octal digits 
sandwiched between “$S” and “’,”’. 

Sum-check field immediately follows end code. 
Sum-check field optional in the input mode and always 
included in the output mode. 

The most significant octal digit of the sum-check may be 
@ or 1 when expressing 16 bits as 6 octal characters. 


Figure A-7. Syntax of the Sum-Check Field in 1/0 
Operations 


Output is begun by invoking an output-to-port operation. 
The programmer divides the output data into 8-line blocks. 


Data transmission is begun with the start code, a 
nonprintable STX, optionally SOH.* Data blocks follow, 
each one prefaced by an address for the first data byte in 
the block. The end of transmission is signalled by the end 
code, a nonprintable ETX. Directly following the end code 
is a sum-check of the transferred data. 


* ASCil-Octal SMS and ASCII-Hex SMS use SOM (CTRL R) as a 
start code and EOM (CTRL T) as an end code. 
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A.6 MICROPROCESSOR FORMATS 


Data in these formats is Srganized: into feces 


codes. Each format has record start chen and sum- 
checks. Records are independent; that is, the programmer 
can addresses in nonsequential order. (The Fairchild 
Fairbug format differs from the other microprocessor 
formats in address setting. See the Fairchild Fairbug format 
description.) 


accept 


¢ RCA COSMAC FORMAT, CODE 70 


Data in this format begins with a start record consisting of 
the start character ('M or ?M), an address field, and a 
space. See figure A-8. 


The start character ?M is sent to the programmer only by a 
development system. This happens when the operator 
enters the interrogation ?M at a terminal (linked in parallel 
with the programmer to the development system), foiiowed 
by the address in the development system memory where 
data transmission is to begin, foiiowed by a number of 
bytes to be transferred, then by a carriage return. The 
development system responds by sending ?M to the 
programmer, followed by the starting address, and a data 
stream which conforms to the data input format described 
in figure A-5. Transmission stops when the specified 
number of bytes have been transmitted. 


INPUT 
DATA RECORD 


¢ 


AAAA = Optional address field. Any record may have 
address specification if end character of previous record 
is a semicolon. 


HH = One data byte in hexadecimal notation 


rTrrrrcxiricyrrpryp 


End-of-Record character. Comma, if address of succeeding 
record follows sequentially; semicolon, if an address field is 
specified in succeeding record. 


This space used for carriage return 


(Beginning of next record) 


OUTPUT 
NOTES 


1) Number of bytes per record is variable. See Table 3-1. 
2) Each line ends with nonprinting line feed, carriage return 
and nulls. 


Start Record 2 Hex characters = 1 byte Data Records 


ae \ 


HHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHH, (CR) 
HHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHH , (CR) 
HHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHH (CR) 
HHHHHHHHHHHHHHHHHHH HHHHHHHHHHHHH CR) 


HHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHG ICR) 


HHHHHHHHHHHI(CR) 
as End-of-File Record 


END-OF-FILE RECORD 


Carriage return. CR without preceding comma or semi- 
colon indicates end of data. 


START-OF-FILE RECORD 


START CHARACTERS 
{f 27M, programmer will ignore any character 


following the space until a carriage return is input. 


AAAA = Address of the first data byte in the record. 
Address may be 1-4 characters: if less than 4, leading zeros 
are assumed. 


One space must precede the first data byte. 


) | poe 


LEGEND 


'Mor 2M = Start Characters 
AAAA = Address Field 
HH = Two Hexadecimal Digits (0-9, A-F) 


° 


= Eadiot: Record Character if followed by expressed address 


(CR) = Nonprinting Carriage Return 


Figure A-8. Specifications for RCA Cosmac Data Files 
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Address specification is required for only the first data byte 
in the transfer. An address must have 1 to 4 hex 
characters and be followed by a space. The programmer 
records the next hex character after the space as the start 
of the first data byte. (A carriage return must follow the 
space if the start code ?M is used.) Succeeding bytes are 
recorded sequentially. 


Each data record is followed by a comma if the next record 
is not preceded by an address, or by a semicolon if it starts 
with an address. Records consist of data bytes expressed 
as two hexadecimal characters and followed by either a 
comma or semicolon, and a carriage return. Any characters 
received between a comma or semicolon and a carriage 
return will be ignored by the programmer. 


The carriage-return character is significant to this format 
because it can signal either the continuation or the end of 
data flow; if the carriage return is preceded by a comma or 
semicolon, more data must follow; the absence of a 
comma or semicolon before the carriage return indicates 
the end of transmission. 


Output data records are followed by either a comma or a 
semicolon and a carriage return. The Start-of-File records 
are expressed exactly as for input. 


INPUT 


DATA RECORD 


START CHARACTER 


HH = One data byte in hexadecimal notation 


NOTE: 
There are always 8 data bytes per record in F8 Format 


C = Checksum. One-digit summation of data in record 


OUTPUT 
NOTES 


1) Output always has 8 data bytes per record. 
2) Each line ends with nonprinting line feed, carriage return 
and nulls. 


2 Hex characters = 1 byte Data Records 


SAAAA xX 5 
XHHHHHHHHHHHHHHHHC 
XHHHHHHHHHHHHHHHHC 
SAAAA 
XHHHHHHHHHHHHHHHHC 
* 


¢ FAIRCHILD FAIRBUG, CODE 80 


In the Fairbug format, input and output requirements are 
identical; both have 8-byte records and identical control 
characters. Figure A-9 simulates a Fairbug data file. A file 
begins with a 5-character prefix and ends with a one- 
character suffix. The Start-of-File character is an “S”, 
followed by the address of the first data byte. Each data 
byte is represented by 2 hexadecimal characters. 


NOTE 
Address specification is optional in this 
format; a record with no address directly 
follows the previous record. 


A 1-digit hexadecimal checksum follows the data in each 
data record. The checksum represents, in hexadecimal 
notation, the sum of the binary equivalents of the 16 digits 
in the record; the half carry from the fourth bit is ignored. 


The programmer ignores any character (except for address 
characters) between a checksum and the start character of 
the next data record. These spaces can be used for any 
comments. 


The last record consists of an asterisk only, which indicates 
the end of data transmission. 


START-OF FILE RECORD 


4 START CHARACTER 


A4SAA = Address of first data byte in file. AAAA in 
hexadecimal notation only 


rPPPp 


END-OF FILE RECORD 


LEGEND 
Ss = START CHARACTER 
AAAA = Address Field 
x = Data-Record Start Character 
HH = Two Hexadecimal Digits (0-9, A-F) 
Cc = Checksum 


Figure A-9. Specifications for Fairchild Fairbug Data Files 
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* MOS TECHNOLOGY FORMAT, CODE 81 ignore all characters received prior to the first semicolon. 
The Hata Baek VeeOId Ie Sandwiched Banwesn-a All other characters in a valid record must be valid hex 
digits (0-9, A-F). A 2-digit byte count follows the start 


7-character pref ix a and a 4-character suffix. The number of h d 
character. The byte count, expressed in hexadecimal digits, 
data bytes in each record must be indicated by the byte Y P gis 


must equal the number of data bytes in the record. The 
next 4 digits make up the address of the first data byte in 
ine record. Data bytes follow, each represented by 2 
Figure A-10 simulates a series of valid data records. Each hexadecimal digits. 


data record begins with a semicolon. The programmer will 


count in the orefix. The input file can be divided inte 
records of various length. 


INPUT 
DATA RECORD END-OF-FILE RECORD 


START CHARACTER START CHARACTER 


: Byte Count. BC = 00 in End-of-File Record 
BC = Byte Count. The hexadecimal number of data bytes Sa 


in the record 


AAAA = Address of first data byte in record. AAAA in 
hexadecimal notation only 


: : . Checksum 
HH = One data byte in hexadecimal! notation 


OUTPUT 
NOTES 


CCCC = Checksum. Two-byte binary summation of 1) Number of bytes per record is variable. See Table 3-1. 
preceding bytes in record (including address, and byte 2) Each line ends with nonprinting line feed, carriage return 
count) in hexadecimal notation. and nulls. 


This space can be used for line feed, carriage return or 2 Hex characters = 1 byte Data Records 


comments. Ne 


(Beginning of next record) —_~ 
/BCAAAAHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHCCCC 
SBCAAAAHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHCCCC 
/BCAAAAHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHCCCC 
iBCAAAAHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHCCCC 
LEGEND /BCAAAAHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHCCCC 
iBCAAAAHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHCCCC 
IBCAAAAHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHCCCC 
‘BCRRRRCCCC 


; = Start Character 
BC = Byte Count (BC> 00 in Record; BC = 00 in End-of-File Record) 
AAAA _— = Address Field 

= Checksum of Record 

= Record Count 

= Two Hexadecimal Digits (0-9, A-F) 


Figure A-10. Specifications for MOS Technology Data Files 
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¢ MOTOROLA EXORCISER FORMAT, CODE 8&2 


Motorola data files may begin with a sign-on record, which 
is initiated by the code SO. Valid data records start with an 
8-character prefix and end with a 2-character suffix. Figure 
A-11 demonstrates a series of valid Motorola data records. 


Each data record begins with the start characters “S1”; 
the programmer will ignore all earlier characters. The third 


INPUT 
DATA RECORD 


START CHARACTERS 


BC = Byte Count. The number of data bytes plus 3 (1 for 
checksum and 2 for address) in hexadecimal notation 


AAAA = Address of first data byte in record. AAAA in 
hexadecimal notation only 


HH = One data byte in hexadecimal notation 


a CC = Checksum, One's complement of binary summation 
Cc 


of preceding bytes in record (including byte count, address, 
c and data bytes) in hexadecimal notation 


This space can be used for line feed, carriage return or 
comments 


(Beginning of next record) 


LEGEND 
so = Optional Record Start Characters 
$1 = Start Characters 
BC = Byte Count 
({Data Bytes/Record] + 3) 
AAAA = Address of First Data Byte 
HH = Two Hexadecimal Digits (0-9, A-F) 
cc = Checksum of Record (one byte) 


and fourth characters represent the byte count, which 
expresses the number of data, address and sum-check 
bytes in the record. The address of the first data byte in 
the record is expressed by the last 4 characters of the 
prefix. Data bytes follow, each represented by 2 
hexadecimal characters. The number of data bytes 
occurring must be three less than the byte count. The 
suffix is a 2-character checksum. 


SIGN-ON RECORD (OPTIONAL) 


SQ = Start characters of sign-on record. Except for start characters, 
S@ record has same format as data record. 


END-OF-FILE RECORD 


START CHARACTERS 


B Byte Count. BC = 03 in End-of-File Record 
Cc 
A 
A Address 
A 
A 
Checksum 


OUTPUT 
NOTES 


1) Number of bytes per record is variable. See Table 3-1. 

2) Each line ends with nonprinting line feed, carriage return 
and nulls. 

3) Sign-on record may precede data. 


2 Hex characters = 1 byte Data Records 


\ 


S1BCAAAAHHHHHHHHHHAHHHHHHHHHHHHHHHHHHHHHCC 
SiBCAAAAHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHCC 
S1BCAAAAHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHCC 
S1BCAAAAHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHCC 
S9BCAAAACC 


Figure A-11. Specifications for Motorola Data Files 
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° INTEL INTELLEC 8/MDS FORMAT, CODE 83 


intel data records begin with a 9-character prefix and end 


capth, ma © nh anrantar 
WILT d Z-UliGIGULS! SUTTIA. ENG wyto Goulle tiiu 


enffiy Tha huta roaiunt miet anal t 
we a1 fl 


number of data bytes in the record. 


Figure A-12 simulates a series of valid data records. Each 


record begins with a colon, which is followed by a 
2-character byte count. The 4 digits following the byte 
count give the address of the first data byte. 


Each data byte is represented by 2 hex digits; the number 
of data bytes in each record must equal the byte count. 


INPUT 
DATA RECORD 


“a Paley 


H 


. 

7 

| | 
c 
C 

| ~~—.. 

LEGEND 
BC 


AAAA 
TT 


START CHARACTER 


BC = Byte Count. The hexadecimal number of data bytes 
in the record 


AAAA = Address of first data byte in record. AAAA in 
hexadecimal notation only 


TT = Record Type (00) 


HH = One data byte in hexadecimal notation 


CC = Checksum. Negation (two’s complement) of binary 
summation .of preceding bytes in record (including byte 
count, address, and data bytes) in hexadecimal notation 
This space can be used for itne feed, carriage return or 
comments. 


= Start Character 
= Byte Count (Data Bytes/Record) 
= Address Field 


= Record Type 
= One Hexadecimal Digit (0-9, A-F) 
= Checksum of Record 


END-OF-FILE RECORD 


Pas START CHARACTER 


Address 


Byte Count. BC = 00 in End-of-File Record 
A 
A 
A 
A 
T 
Tr 


TT = Record Type (01) 


Checksum 


NOTES 


1) Number of bytes per record is variable. See Table 3-1. 
2) Each line ends with nonprinting line feed, carriage return 
and nulls. 


2 Hex characters = 1 byte Data Records 


‘Ny 


:BCAAAATTHHHHHHHHHHAHHHHHHHHHHHHHHHHHHHHHCC 
:BCAAAAT THHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHCC 
:BCAAAAT THHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHCC 
: BCAAAATTFF 


Figure A-12. Specifications for Intel Intellec 8/MDS Data Files 
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e SIGNETICS ABSOLUTE OBJECT FORMAT, CODE 85 address check. Data is represented by pairs of hexadecimal 
characters. The byte count must equal the number of data 
bytes in the record. The suffix is a 2-character data check, 
calculated using the same operations described in figure 
A-13 for the address check. 


Figure A-13 shows the specifications of Signetics format 
files. The data in each record is sandwiched between a 
9-character prefix and a 2-character suffix. 


The start character is a colon. This is followed by the 
address of the first data byte, the byte count, and a 2-digit 


INPUT 
DATA RECORD END-OF-FILE RECORD 


START CHARACTER Bx START CHARACTER 


AAAA = Address of the first data byte in record. AAAA in 
hexadecimal notation only Address 


BC = The hexadecimal number of data bytes in the record Byte Count. BC = 00 in End-of-File Record 


AC = Address Check. Every byte is exclusive ORed with 
the previous byte, then rotated left one bit. 


HH = One data byte in hexadecimal notation. 


OUTPUT 
NOTES 


1) Number of bytes per record is variable. See Table 3-1. 
; 2) Each tine ends with nonprinting line feed, carriage return 

D DC = Data Check. Every byte is exclusive ORed with the and nulls 

Cc previous byte, then rotated left one bit. , 
This space can be used for line feed, carriage return or 


comments. 2 HEX characters ~ 1 byte Data Records 


\ 


-AAAABCACHHHHHHHHHAHHHHHHHHHHHHHHHHHHHHHHDC 
-AAAABCACHHHHHHHHHHHHHHHHHHHHHHHHHHHHAHHHHDC 
‘“AAAABCACHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHDC 


ae 


(Beginning of next record) 


LEGEND :AAAABCACHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHDC 
: = Start Character “AAAABCAC 

AAAA = Address Field 

BC = Byte Count (Data Bytes/Record) 

AC = Address Check. Checksum of address and byte count 

HH = Two Hexadecimal Digits (0-9, A-F) 

DC = Data Check. Checksum of data in record 


Figure A-13. Specifications for Signetics Absolute Object Data Files 
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°¢ TEKTRONIX HEXADECIMAL FORMAT, CODE 86 


Figure A-14 illustrates a valid Tektronix data file. The data 
in each record is sandwiched between the start character 
(a slash) and a 2-character sum-check. Following the start 
character, the next 4 characters of the prefix express the 
address of the first data byte. The address is followed by a 
byte count, which represents the number of data bytes in. 
the record, and by a sum-check of the address and byte 
count. Data bytes follow, represented by pairs of 


hexadecimal characters and succeeded by a sum-check of 


INPUT 
DATA RECORD 


/ = Start Character 


AAAA = Address of the first data byte in the record 
(hexadecimal notation) 


BC = Byte Count. The hexadecimal number of data bytes 
in the record 


CC = Checksum. Ejight-bit sum of the four-bit hexadecimal 
values of the six digits that make up the address and byte 
count (hexadecimal notation) 


HH = One Gaia Dyie in nexadecimai notation 


{== 


CC = Checksum. Eight-bit sum, modulo 256, of the 
four-bit hexadecimal values of the digits that make up the 
data bytes 


Carriage return 


(Beginning of next record) 


Cc 
= 


OUTPUT 


2) Each line ends with nonprinting line feed, carriage return 
and nulls. 


2 Hex characters = 1 byte ‘~ 


/AKAAABCCCHHHHHHHHHHAHHHHHHHHHHHHHHHHHHHHHCC 
/AAAABCCCHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHCC 
/AAAABCCCHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHCC 
/AAAABCCCHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHCC 


/AAAABCCC 
End-of-File Record 


NOTES 
1) Number of bytes per record is variable. See Table 3-1. 


Data Records 


the data bytes. The End-of-File record consists only of 


control characters used to signal the end of transmission 
and a byte count and sum-check for verification. 


Data is output from the programmer starting at the first 
RAM address and continuing until the number of bytes in 
the specified block have been transmitted. The programmer 
divides output data into records prefaced by a start 
character and an address field for the first byte in the 
record. 


ABORT RECORD 


// = Two Start Characters 


XX...X = Arbitrary string of ASCii characters 


Carriage return 


END-OF-FILE RECORD 


/ = Start Character 


AAAA = Transfer Address 


BC = Byte Count. BC = 00 in End-of-File record 


CC = Checksum. Eight-bit sum of the four-bit hexadecimal 
values of the six digits that make up the transfer address 
and the byte count (hexadecimal notation) 


Carriage return 


LEGEND 

/ = Start Character 

AAAA = Address Field 

BC = Byte Count (Data Bytes/Record) 
cc = Checksum 

HH = Two Hexadecimal Digits (0-9, A-F) 
Xx = Any ASCII Character 


Figure A-14. Specifications for Tektronix Hexadecimal Data Files 
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¢ MOTOROLA EXORMAX FORMAT, CODE 87 6 characters. The third and fourth characters represent the 
byte count, which expresses the number of data, address and 
checksum bytes in the record. The address of the first data 
byte in the record is expressed by the last 4 characters of the 
prefix (6 characters for addresses above hex FFFF). Data bytes 
follow, each represented by two hexadecimal characters. The 
number of data bytes occurring must be 3 or 4 less than the 


Each data record begins with the start characters S1 or S2— byte count. The suffix is a 2-character checksum. 
S1 if the following address field has 4 characters, S2 if it has 


Motorola data files may begin with a sign-on record, 
initiated by the code SO. Data records start with an 8- or 
10-character prefix and end with a 2-character suffix. 
Figure A-15 demonstrates a series of Motorola Exormax 
data records. 


INPUT 
DATA RECORD 


SIGN-ON RECORD (OPTIONAL) 


S@= Start characters of sign-on record. Except for start 
SS START CHARACTERS. S1 if following address field has 4 characters; characters S@ record has same format as data record. 
S2 if address field has 6 characters. 


BC=Byte Count. The number of data bytes plus 3 or 4 (1 for 


C checksum and 2 or 3 for address) in hexadecimal notation. END-OF-FILE RECORD 

A 

A 

re S$ S$ START CHARACTERS. Must be $9 if previous data record 
x AAAA or AAAAAA = Hexadecimal address of first data byte in record. 8 or 9 began with S1. May be $8 or S9 if previous record 

A began with S2. 

A 


Byte Count. BC = 03 in End-of-File Record. 


H 
A 
a A 
H HH = One data byte in hexadecimal notation. A Address. Always 0080 in End-of-File Record. 
A 
Checksum 
Cc CC = Checksum. One’s complement of binary summation of preceding 
bytes in record (including byte count, address, and data bytes) 
C in hexadecimal notation. 


OUTPUT 


NOTES 


This space can be used for line feed, carriage return or comments. 
The programmer will ignore any characters inserted between the 
last checksum and the start characters of the next record. 


1) Number of bytes per record is variable. 

2) Each line ends with nonprinting line feed, carriage return 
and nulls. 

3) Sign-on record may precede data. 


(Beginning of next record) 


2 Hex characters = 1 byte Data Records 


om) 

SIBCAAAAHHHHHHHHHHHHAHHHHHHHHHHHHHHHHHHHHCC 
S1BCAAAAHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHCC 
S1BCAAAAHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHCC 
S1BCAAAAHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHCC 
S2BCAAAAAAHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHCC 
S2BCAAAAAAHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHCC 
SSBCAAAACC 


sO = Optional Record Start Characters 
$1 = Start Characters 
BC = Byte Count ([Data Bytes/Record] + 3 or 4) 


= i ta B 
AMAAAA Address of First Data Byte 


HH = Two Hexadecimal Digits (0-9, A-F) 
CC = Checksum of Record (one byte) 


End-of-File Record 


Figure A-15. Specifications for Motorola Exormax Data Files 
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e INTEL MCS-86 HEXADECIMAL OBJECT. CODE 88 


The intel 16-bit Hexadecimal Object file record format has a 
character (4-field) prefix that defines the start of record, 

byte count, load address, and record type and a 

2-character checksum suffix. Figure A-16 illustrates the four 


types of records used with this format. 


co 


INPUT 


DATA RECORD (record type 09) 


START CHARACTER 


BC - Byte Count. The number of data byte: in hexadecimal 


notation 


AAAA - Address of first data byte in record. AAAA in 
hexadecimal notation only 


Record Type = 00 


HH = One data byte in hexadecimal notation 


| 
CC =Checksum. Negation (two’s complement) of binary 


summation of preceding bytes in record (including bytecount, address, 


and data bytes) in hexadecimal notation 


This space can be used for line feed, carriage return or comments 


Beginning of data record 


LEGEND 


SO = Optional Start-of-File Record 
$1= Start Characters 
SC = Byte Count 
({Data Bytes/Record] + 3) 
AAAA = Address of First Data Byte 
HH =Two Hexadecimal Digits (0-9, A-F) 
CC = Checksum of Record (one byte) 
* Always = @ for output 


| | LLow order 16 bits of a 20-bit address 


The four record types are: 


@@ = data record 

@1 = end record (signals end of file) 

@2 = extended address record (added to the offset to 
determine the absolute destination address) 

@3 = start record (ignored during input and not sent during 
output by Data i/O translator firmware) 


END OF FILE RECORD (record type 01} 


START CHARACTER 


“= Byte Count=@@ in End-of-File Record 


Address Field (always zero) 


Record Type=01 


, E peel oe 


Checksum = FF 


ee 
n 
Te 


OUTPUT 
NOTES 

1) Number of bytes per record is variable. See table 3-1. 

2) Each line ends with nonprinting line feed, carriage return and 

nulls. 

: 02 @8 @8 02 ;|HHHO,CC 

: BC,@@ AA,@B HHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHH CC 

: BC @@ AA 0 HHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHH CC 

: BC @@ AA 00 HHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHH CC 

: BC 08 AA @ HHHHHHHHHHHHHHHHHHHHHHHHHHHHHHEH CC 

: BC @@ AA 00 HHHHHHHHHHHHHHHHHHHHHHHHHHHHHHHH CC 

: 0 00 00 01 FF . 


High order 16 bits of a 20-bit address 


Figure A-16. Specifications for Intel MCS-86 Hexadecimal Object (Code 88) Data Files 
-Continued on Next Page- 
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INPUT 


EXTENDED ADDRESS RECORD (record type 02) START ADDRESS RECORD (record type @3) 
(not used by Data !/O firmware) 


START CHARACTER START CHARACTER 


Byte Count = 02 Byte Count = 04 


Address Field (always zero) Address Field = 0800 (always zero) 


Record Type=02 Record Type = 03 


Alor a 2 


H 

HH = Offset data (2 bytes; highest order 16 bits of H : 

20 bit address H Start execution code segment 
a = 

CC = Checksum. Negation (two’s complement) of binary 

summation of preceding bytes in record {including bytecount, address, H 

and data bytes) in hexadecimal notation H Start execution instruction pointer 
H 

This space can be used for line feed, carriage return or comments H 

Beginning of data record Cc cc 
Cc Checksum 


LEGEND 


SO = Optional Start-of-File Record 
$1= Start Characters 
SC = Byte Count 
({Data Bytes/Record] + 3) 
AAAA = Address of First Data Byte 
HH = Two Hexadecimal Digits (0-9, A-F) 
CC = Checksum of Record (one byte) 
* Always = @ for output 


Figure A-16. (Continued) 
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Record type 92, the extended address record, defines bits 4 
to 19 of the segment base address. It can appear randomly 
anywhere within the object file and in any order; i.e., it 

can be defined such that the data bytes at high addresses 
are sent before the bytes at lower addresses. Figure A-17 
illustrates how the extended address is used to determine a 
byte address. 


Example of How to Calculate Address 


Problem: Find address for the first data byte for the 
following file. 


:02 0000 02 1230 BA 
:10 0045 00 55AA FF BC 


Solution: 
Step 1: Find the record address for the byte. The first 
data byte is 55. Its record address is 0045 from above. 


Step 2: Find the base address (offset). The base address 
is 1230 from above. 


jem 


tep 3: Shift the base address one place to the left an 
then add to the record address. 


Base Address 1230 (upper 16 bits) 
+ Record Address 0045 _ (lower 16 bits) 
Address for first data byte = 12345 (20-bit address) 


| | 


Figure A-17. Calculating an Address Using the 
Intel MCS-86 (Code 88) Extended 
Address Board 


NOTE 
Aways specify the address offset when 
using this format, even when the offset 
is zero. 


During output translation, the firmware will force the 
record size to 16 (decimal) if the record size is specified 
greater than 16. There is no such limitation for record sizes 
specified less than 16. 


¢ HEWLETT-PACKARD 64000 ABSOLUTE FORMAT, 
CODE 89 


Hewlett-Packard Absolute is a binary format with control 
and data-checking characters. See figure A-18. 


checksum of the bytes in the record. 


Data records follow the Start-of-File record. Each begins 
with 2 byte counts: the first expresses the number of 
16-bit words in the record not including the checksum and 
itself; the second expresses the number of 8-bit data bytes 
in the record. Next comes a 32-bit address, which 
describes the storage location of the following data byte. 
Data bytes follow; after the last data byte comes a 
checksum of every byte in the record except the first byte. 


The End-of-File record consists only of a byte count, which 
is always zero. 


* TEXAS INSTRUMENTS SDSMAC FORMAT, 
CODE 90 


Data files in the SDSMAC format consist of a Start-of-File 
record, data records, and an End-of-File record. See 
figure A-19. 


Each record is composed of a series of smail fields, each 
initiated by a tag character. The programmer recognizes 
and acknowiedges the foiiowing tag characiers: 

Q 
7 


always followed by a file header. 


always followed by a checksum which the 
programmer acknowledges. 


8 - always followed by a checksum which the 
programmer ignores. 


9 - always followed by a load address. 
B - always followed by 4 data characters. 
F - denotes the end of a data record. 


The Start-of-File record begins with a tag character and a 
12-character file header. Next come interspersed address 
fields and data fields (each with tag characters). If any data 
fields appear before the first address field in the file, the 
first of those data fields is assigned to address 0000. 
Address fields may be expressed for any data byte, but 
none are required. The record ends with a checksum field 
initiated by the tag character 7 or 8, a 4-character 
checksum, and the tag character F. 


Data records follow the same format as the Start-of-File 
record but do not contain a file header. 


The End-of-File record consists of a colon (:) only. The 
output translator sends a control S after the colon. 
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HIGH 
ORDER 


LOW 
ORDER 


END-OF-FILE 
RECORD 


<= End-of-File record consists only of a byte count of @. 


Checksum 


Data bytes 


ONE DATA 
RECORD 


Address where following data byte is to be stored. 


+ Byte Count. Number of 8-bit data bytes. 


= Word Count. Number of 16-bit words in record except checksum and itself. 
> Checksum. Modulo 256 sum of all bytes in the record except the first byte. 


Transfer address for microprocessor program counter. 


START-OF-FILE 
RECORD 


+ Data Word Width: the number of bits in the smallest data word. 


+ Data Bus Width, usually 8 or 16. 
<= Word Count. Number of 16-bit words in the record. Always 04 in Start-of-File record. 


NOTE 


This format is binary. Therefore, no ASCII control 
characters or carriage returns and line feeds are 
allowed. 


Figure A-18. Specifications for Hewlett Packard Absolute Format Data Files 
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INPUT 
START-OF-FILE RECORD 


Tag Character. Always followed by a file header. 


EL 


File Header. 
XXXX = hexadecimal byte count of 16-bit data bytes in the record. 


YYYYYYYY = name of file. May be any ASCII character in 
hexadecimal notation. 


<<<««<<<<x > 


Optional Tag Character. Always followed by a load address. Tag 
characters 9 and B may come in any order. 


Load Address: 4-character hexadecimal address of first data byte in 
the record. 


Tag Character. A ‘’B’ must precede every 4 data characters. 


HH = 2-character hexadecimal data byte. 


8, programmer will ignore the checksum. 


Hexadecimal Checksum. Two's complement of the sum of the 8-bit 
ASCII values of the characters in the record from the first tag 
character through the checksum tag (7 or 8). 


Tag Character. Denotes end of the data record. All characters 
following F before line feed and carriage return will be ignored. 


NOTES 


1)Number of bytes per record is variable. 
2)Each line ends with nonprinting line feed, carriage return and nulls. 


Start-of-File 
Record 


Data 
Records 


OXXXXYYYYYYYYSAAAABHHHHBHHHH...7CCCCF 
BHHHHBHHHHBHHBHHBHHHHBHHHH ....7CCCCF 
BHHHHBHHHHBHHHHBHHHHBHHHEH....7CCCCF 
BHHHHBHHHHBHHHHBHHHHBHHHEH....7CCCCF 


| 

| 

| 

| 

| 

| 

1 | 
OUTPUT 


AN End-of-File oe 


2 Hex Characters = 1 byte 


F 
Tag Character. Must be followed by a 4-character checksum field. If 


DATA RECORD 


Optional Tag Character. Always followed by a load address. Tag 
characters 9 and B may come in any order. 


AAAA = Load address: 4-character hexadecimal address of first 
data byte in the record. 


Tag Character. A ‘’B’’ must precede every 16-bit data byte. 


HH = 2-character hexadecimal data byte. 


Tag Character. Must be followed by a 4-character checksum field. 
If 8, checksum will be ignored by programmer. 


Checksum in hexadecimal notation. Two’s complement of the sum of 
£ 
& 


eA eS INE aM ee as Aa eet Som th 
INE G-DH AOULH VaIUES OT Ne Ciiatactteis i wie roLUrU Tron wic 


tag character through the checksum tag (7 or 8). 


Tag character. Denotes end of data record. All characters following F 
before line feed and carriage return will be ignored. 


END-OF-FILE RECORD 


End-of-file character 


LEGEND 


0,7,8,9,B,F = Tag Characters 

AAAA = Address Field 

XXXX = Byte Count 

YYYYYYYY = File Name 

HH = Two Hexadecimal Digits (0-9, A-F) 
CCCC = Checksum 


Figure A-19. Specifications for Texas Instruments SDSMAC Data Files 
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APPENDIX B 
TERMINAL REMOTE CONTROL (TRC) 


B.1 INTRODUCTION 


This section summarizes the commands available for data 
transfer, editing, or review via Terminal Remote Control 
(TRC) for the 29B Programmer. 


Figure B-1 shows the link between the 29B programmer 
and the remote system. When in Terminal Remote Control, 
all data manipulations are controlled remotely, either by a 
computer, manual data entry, or by a data transferring 
device, such as a tape reader. Existing RAM data is edited 
by any of the editing commands or by the various 
commands invoked while the programmer is in the Memory 1 
Mode. Edited RAM data can then be programmed into a 

device. 


Data blocks transferred between the programmer and a 
device are in binary. Data blocks transferred between the 
remote system and the programmer are coded in a format 
specified by the operator (see the appendix A for 
description of the various data translation formats). 


The programmer, under control of the terminal, executes 

the commands entered at the terminal and returns the _ 

prompt character (>) to the terminal upon successful 2. 
execution of a command. When in the memory mode the 

current RAM address location and the data at that location 

are displayed. 


TELETYPE 
TERMINAL 
WITH 
PAPER TAPE 
READER 
AND PUNCH 


CURRENT LOOP DATA LINK l 


REMOTE 
CONTROL 


RS232 DATA LINK 
$$ nn 


TERMINAL 


| 

| 

I 

\ 

COMPARE 

| OUTPUT 
j 

’ 


B.2 SYSTEM VARIATIONS 


The TRC system is not recommended for newly designed 
computer controlled programming systems; whereas, the 
CRC remote system is recommended (see subsection 
3.9.1). However, since TRC has been widely used in the 
past with the System 19, it has been adapted to operate 
with the 29B. The few differences in operation between the 
System 19 and the Model 29B TRC are listed below; 
however, these should not require any significant changes 
in existing TRC programming system software and drivers. 


. All memory address related commands will take longer 


with 29B because it allows for up to 64k addressing 
which requires more software execution because of 
page addressing. These commands include all the 
major commands: “PG” (Program), ‘‘LD’” (Load), 
“VE” (Verify), ‘DI’ (Data Input), ‘DC’ (Data 
Compare), and “DO” (Data Output) as well as less 
significant commands such as “SC” (Sumcheck}, 
“CA” (Clear All RAM), “CM” (Complement Memory), 
“SN” (Swap Nibbles), and “SD” (Split RAM Data). 


Memory mode commands which manipulate or search 
all 64k bytes of memory will require at least four times 
more time to perform their operation. These 
commands include: | (Insert Data), D (Delete Data), U 
(Fill Unprogrammed Data), S (Search Data), B 


(Substitute Data). 


Programmer 


RANDOM 
ACCESS 
MEMORY 


VERIFY 


PROGRAM 


Figure B-1. System Configuration Between Programmer and Terminal Remote Control 
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3. The 29B message displayed on the terminal when first 
entering TRC has one extra line-feed preceding the 
text. Otherwise these messages are the same. 


4. For the Model 29B after the end of an input or input 
compare data translation there must be a pause of 
incoming characters for 1/2 second before the prompt 
is returned. All incoming characters after the end of 
data translation and before the returning prompt are 
purged (thrown away). 


5. The System 19 sends out an extra carriage return, 
linefeed, and null count after the STX (start character) 
for formats 01 through 09, 12, 13 whereas the model 
29B does not. 


6. The Model 29B sends out an extra carriage return, 
linefeed, and null count after the leader for formats 10 
and 11 whereas the System 19 does not. 


7. During input or input compare translation the System 
19 beeps each time an error occurs whereas the Model 
29B does not. 


8. For the Model 29B a BREAK or ESCAPE key 
depressed during input or input compare translation 
will abort the operation just as with System 19, 
however, the Model 29B will not return a prompt until 
data stops coming in. 


9. The “SM” (Memory Size) command with the Model 
29B will show only the lower 16 bits of a 17-bit ending 
address if the “VM” (Virtual Memory Offset) command 
has been defined to be greater than zero. If the 
address offset is equal to zero (its default value) then 
there is no problem since the ending address can be 
shown with 16 bits. 


10. Generally the quantity of errors given in response to 
“QB” (Input Compare Errors), “QC” (Buffer-Overflow 
Errors), and “QD” (Error Status) commands will be the 
same for both the System 19 and the Model 29B, 
however for some translators the quantity may be 
different. 


B.3 COMMAND GROUPS 


The commands available in remote control are grouped 
according to their functions. Tables B-1 through B-6 
summarize the commands available in remote-control 
operation of the programmer, as well as programmer 
responses to these commands. Syntax for the commands 
in the summary tables is shown in section B.4. 


Control-Key Commands 


The Control-Key Commands summarized in table B-1 are 
used to execute or suspend a command, or to display the 
last command. 


Table B-1. Control-Key Commands. 


COMMAND 
ESC/BREAK 


SPACE 


LINE FEED 


RETURN [CR] 


DESCRIPTION 


Abort a command. The BREAK key is used to abort a binary 
data transfer. Note: When using during the execution of the 
“DI” or “DC command may not abort the command if a data 
stream continues to come into the programmer from the remote 
terminal or computer. 


Re-executes the D, | and C commands. Note: With the ‘C’ and 
‘I’ command the data parameter must be entered each time. 


Displays the last command executed. Note: Does not function 
for memory mode commands. 


Executes a command or re-executes a previous command. The 

letters [CR] are used in this appendix to represent the return, or 
carriage return command. Note: Does not function for memory 

mode commands. 
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Utility Commands Device Commands 


The Utility Commands summarized in table B-2 set some The Device Commands summarized in table B-3 execute 
generai operating parameters required in many operations. the basic operations used in programming: Load, Program, 
Verify, etc. 


Table B-2. Utility Commands 


COMMAND DESCRIPTION 

KF [AD] Keyboard Format Sets number based (A/D) for address and data entry. Default 
Value - Hexadecimal. 

CN Configuration Number Programmer outputs the software configuration identification 
number. 

NM Nibble Mode Selects a 4-bit word size to override 8-bit programming 
modules. 

BM Byte Mode Nullifies the Nibble Mode command. 

SM Size Memory Terminal displays beginning and ending RAM addresses. The 
address-offset value is the beginning address (see ‘“VM’’). The 
ending RAM address is the beginning address plus the available 
RANMA siza 

Function some programming modules. 
SC Sumcheck Programmer sends sumcheck of all RAM data to terminal. 


Note: If data in RAM has been recently changed the operator 


SF [SC] Select External Allows entry of Select Codes (SC) carried in software on 
should wait three seconds before issuing this command to get 


valid results. 
cc No Operation 
ZP Exit Terminal Remote Control returns to programmer keypanel. 
Control 


Table B-3 Device Commands 


COMMAND DESCRIPTION 


CD Clear Device Programmer clears the count of consecutive program 
, Counter operations. 


SP Device Size Terminal displays number of words (bytes) and word size of 
device for which programmer is set up. 


FP Display Family Pinout Multiple device type Paks only; e.g. the UniPak™., Terminal 
displays current device family and pinout codes. 


FY [FF/PP] Select Family Pinout Multiple device type Paks only; e.g. the UniPak™, Selects 
device family and pinout codes. 


PO [PP] Select Pinout Multiple device type Paks only; e.g. the UniPak™. Selects 
device pinout code. 


LD [RAM BEG/BLK Load Device data is loaded into RAM. 
SIZ/DEV BEG] 


PG [RAM BEG/BLK Program RAM data is programmed into device. 
SIZ/DEV BEG]. 


VF [RAM BEG/BLK Verify Device data is verified against RAM data. 
SIZ/DEV BEG] 
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1/0 Commands port. This includes setting a translation format, parity, 


address control, and other considerations fundamental to 
1/O data transfers. 


The I/O commands summarized in table B-4 set up the 
programmer to transmit or receive data through the serial 


COMMAND 


EP 


NP 


DP 


ND [NN] 


RS [RR] 


OS 


TS 


DS 


FM [FC] 


VM [AAAA] 


For 16-bit Format |/O: 


VM [AAAA/AAAA] 
DT 


DI [RAM BEG/ 
BLK SIZE] 


DO [RAM BEG/ 
BLK SIZ] 


DC [RAM BEG/ 
BLK SIZ] 


OA 


Table B-4 1/O Commands 


Odd Parity 


Even Parity 


No Parity 


Default Parity 


Null Define 


Record Size 


Select One Stop Bit 


Select Stop Bits 


Default Stop Bits 


Translation Format 


Virtual Memory Offset 


Disable Timeout 


Data Input 


Data Output 


Data Compare 


1/O Parameters 


Input Compare 


Buffer-Overflow 


Error Status 


DESCRIPTION 


Programmer sets odd parity for data transfer. Default Value - 
programmer's parity- switch setting. 


Programmer sets even parity for data transfer. Default Value 
- programmer's parity-switch setting. 

Programmer sets no parity for data transfer. Default Value - 
programmer's parity-switch setting. 

Programmer returns to default parity value for data transfer, 
which is the programmer’s parity-switch setting. 


Programmer sets number of nulls (NN) to be output after a 
line of data. Default Value - one null. 


Programmer sets number of bytes (RR) per output record in 
formats with variable record lengths. Default Value - 16 bytes 
(8 in Fairchild Fairbug). 


Programmer sets one stop bit for serial data transfers. 
Default Value - programmer's stop-bit switch. 


Two Programmer sets two stop bits for serial data transfers. 
Default Value - programmer’s stop-bit switch. 


Programmer returns to default value for stop bits, which is 
the programmer's stop-bit switch. 


Programmer sets the format code (FC) for data transfer. 
Default Value - format 50, ASCII-Hex (Space). 


RAM beginning is redefined from 0 to value (AAAA). Note: 
During data input translation to the programmer input data is 
offset by (AAAA). 


Disables the 25-second I/O timeout. Restored only by 
power-on. 


Programmer accepts data input from terminal to RAM. 


Programmer sends data from RAM to terminal. 


Programmer compares data from external source with RAM 
data. 


Terminal display 4 sets of characters: the address offset, the 
translation format, the number of nulls and the record size 
currently in effect. 


Programmer outputs the number of misverify errors that 
occurred in an Input operation. 


Programmer outputs the number of input-buffer-overflow 
errors. 


Programmer outputs three figures: the number of missing or 
invalid characters, the number of sumcheck errors (or 
missing F characters in ASCII Binary formats) and the 
number of parity errors. 
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Editing Commands 


The Editing commands summarized in table B-5 manipulate 
RAM data. Several functions are available, such as clearing 
RAM, or filling RAM with a variable. 


COMMAND 


CM [RAM BEG, 
BLK SIZ] 


CA 
SN 


SD [RAM ADR] 


SH [RAM ADR} 


BL [RAM BEG/BLK 
SIZ/RAM ADR] 


MM [RAM BEG] 


MO 


Table B-5. Editing Commands 


Complement 
Memory 


Clear All RAM 
Swap Nibbles 


Split RAM Data 


Shuffle RAM data 


RAM-RAM Block 
Move 


Enter Memory Mode 


Enter Memory Mode 


DESCRIPTION 


Programmer complements RAM data between specified 
addresses. 


Programmer clears all of RAM to zeros. 


Programmer exchanges high-and low-order halves of every 
word in RAM. 


Moves data at even-numbered RAM addresses into one 
block starting at address 0 and ending at the specified center 
point address less 1. Data at odd-numbered addresses 
moves to an adjacent block starting at the specified center 
point. Complement of the SH command. 


Lower of the two blocks of RAM data (starting at RAM 
address 0) moves to even-numbered addresses. Upper biock 
moves to odd-numbered addresses. Complement of the SD 
command. 


Specifies the amount of data to be transferred between one 
location in RAM and another. 


Terminal enters Memory Mode at the specified RAM 
address. 


Terminal enters Memory Mode at the last-displayed address. 
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Memory Mode Commands can be executed. The memory mode command ‘E” 
{Escape Memory Mode) directs the system to exit the 


The Memory Mode commands summarized in table B-6 
“memory mode.” 


also allow editing. These commands allow the operator to 
review or to make changes to data at specific locations in 
RAM. The edit commands ‘‘MM” (Enter Memory Mode - 
specified address) or ‘‘MO” (Enter Memory Mode - last 
displayed address) enter the system into the ‘“memory 
mode” from which any of the memory mode commands 


NOTE 
Errors when in the memory mode will 
cause the system to exit the memory 
mode. 


Table B-6 Memory Mode Commands 
COMMAND DESCRIPTION 


Display Next Address Each N keystroke displays the next-higher RAM address and 
its data. 


Display Last Address Each L keystroke displays the next-lower RAM address and 
its data. 


J [RAM ADRI Jump Address Terminal jumps from displayed RAM address to specified 
address. 


C [DATA] Change Data Displayed data is changed to specified data. 


| [DATA] Insert Data Specified data is inserted in front of displayed data, and all 
subsequent data moves to next-higher address. 


D Delete Data Data at displayed address is removed from memory, and all 
subsequent data moves to next-lower address. 


R [DATA/BLK SIZ} Repeat Data Specified data is placed at selected number of sequential 
RAM addresses. 


F [DATAI Fill Data Specified data is placed at displayed address and all 
addresses up to RAM end of RAM. 


U Fill Unprogrammed Data RAM is filled from specified address to end of RAM with the 
unprogrammed state data for a particular device (defined by 
the Pak family/pinout). 


S {DATA, RAM Search Data Terminal displays alt RAM locations containing specified 
ADR/BLK SIZ] data. 


B [DATA 1/DATA 2/RAM — Substitute Data Valid data 2 replaces valid data 1 between specified 
ADR/BLK SIZ] addresses. 


T IBLK SIZ] List Terminal lists specified RAM addresses and corresponding 
data. 


Escape Memory Mode Terminal exits from Memory Mode. 
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B.4 SYNTAX 


Commands must be keyed in according to the rules of 
syntax listed below. The correct (or typical) syntax for each 
command is illustrated by means of the following symbols: 


Symboi used to enciose a 
command input by the operator. 


Symbol used to enclose a response 
output by the 29B programmer. 


RAM BEG - RAM beginning address. 

BLK SIZ - Address block size, or number of 
bytes. 

DEV BEG - Device beginning address. 

DATA - Valid data nibble, byte. 


NOTE 
These symbols are indicators only. They 
are not entered by the operator as part 
of the commands or output by the 
programmer as part of the responses. 


In a command, a parameter may be omitted if the default 
value is desired. Defaults for specific commands are listed 
in paragraphs B.8.2 through B.8.6. 


For commands that require entering of address or daia, 
this information must be entered using the numerical base 

. in effect, either octal, binary, decimal, or hexadecimal. The 
base is defined by the KF command and the default base is 
hexadecimal. When data is being transferred via the serial 
1/O port, it must conform to translation code format 
defined by the FM command. 


B.5 PROGRAMMER RESPONSES TO 
TERMINAL DATA ENTRY 


The Model 29B Programmer responds to commands 
entered at the terminal in one of three ways: 


1. lf the command has been entered correctly, the 
programmer will execute the command, send a reply to 
the terminal and return the prompt character (> ). 


2. If the operator enters an incorrect Command Code, the 
programmer will return a question mark (?). 


3. If the operator attempts an illegal operation, the 
programmer will either reject an entered command and 
emit a beep, or display ‘““*ERROR” and the error 
number. Errors codes are listed in Appendix E of this 
manual. 
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B.6 SERIAL I/O INTERFACE 


This information is provided in subsection 2.5 of this 
manuai. However, it should be restated that Te 
Remote Control! is full duplex. Thus, for a terminal or 
computer to be properly interfaced it must be set to full 


duplex. 


that Termina! 


B.7 ACCESS TO TERMINAL REMOTE 
CONTROL 


B.7.1 ENTRY 


To place the Model 29B Programmer in terminal remote 
control, enter Select Code F2 on the programmer’s 
keyboard. The terminal will display the Data |/O title block: 
Data |1/O Corp. terminal remote control 
copyright 1979 955-1903 Rev. F. 


Use the following procedure to enter terminal remote 
controi: 


ENTER TERMINAL REMOTE CONTROL Command 


Operation: ENTER TERMINAL REMOTE CONTROL (from 
front panel keyboard) 

Code: F2 

Syntax: [SELECT] [F] (2] [START] [START] 

Explanation: Entered by the operator on the 29B front 
nanel kevhoard to nlace the programmer 
under terminal remote control. 

B.7.2 EXIT 


The operator may use either the terminal or the 29B 
keyboard to exit from terminal remote control. Use the 
applicable of the two following procedures to exit terminal 
remote control: 


EXIT REMOTE CONTROL (from terminal) Command 


EXIT REMOTE CONTROL (from terminal) 

ZP 

(>) (Z] [P] [CR] 

This command causes the terminal to 
surrender control to the programmer. When 
exiting remote control via the ZP command, 
all operating parameters except the virtual 
memory offset will be retained. Upon re- 
entering terminal remote control, the terminal 
will display a prompt character ‘>’ instead 
of the Data I/O title block. The title block will 
display if the programmer has subsequently 
been turned off. 


Operation: 
Code: 
Syntax: 
Explanation: 
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EXIT REMOTE CONTROL (from keyboard) Command 


Operation: EXIT REMOTE CONTROL (from front panel 
keyboard) 

Code: Press any mode key (COPY, VERIFY, 
SELECT, or EDIT) 

Syntax: (>) [any mode (blue) key] 

Explanation: Pressing a mode key on the programmer (any 


blue key) returns control to the front panel. 
All parameters will be retained, and data 
displayed at the terminal before depressing a 
mode key will remain unchanged upon re- 
entering remote control. 


B.8 COMMAND SUMMARY 


The entire Command summary, with commands detailed 
individually, is described in paragraphs B.8.1 - B.8.6. 
Tables B-1 through B-6 summarize the commands. 


NOTE 
The programmer must send the prompt 
character (>) to the terminal before any 
command can be executed. The prompt 
character is sent to the terminal: 


7. on entering remote control 

2. after a previous command has been 
successfully executed 

after either BREAK or ESCAPE has 
halted a command 

after an error message has been 
printed at the terminal. 


3. 


4. 


B.8.1 CONTROL-KEY COMMANDS 


The following are Control-Key Commands: 


ESCAPE (or BREAK) Command 


Operation: ESCAPE and BREAK 

Code: ESC or BREAK 

Syntax: [ESC] or [BREAK] 

Explanation: ESC or BREAK suspend the present 


command at any stage of execution. ESCAPE 
may be used at any time except when 
inputting binary data. Only the BREAK key is 
used to suspend a binary-input operation. 
Note: During input data translation an abort 
will not result in an immediate prompt for a 
new command until the input data stops 
coming in for a period of 1/2 second. 
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SPACEBAR Command 


Operation: SPACEBAR 

Code: SPACE 

Syntax: [SPACEBAR] 

Explanation: In the Memory Mode, SPACE is used to 


partially re-execute the following commands: 
Delete (D), Insert (I) and Change (C). Note: A 
carriage return and any data parameters 
required by these command must still be 
entered before the command is executed. 


LINE FEED Command 


Operation: LINE FEED 
Code: LINE FEED 
Explanation: LINE FEED causes the terminal to display the 


last-executed command (but not to execute 
it). 


NOTE 
The following commands are not re- 
executed by a return or redisplayed by a 
line-feed: DC, Di. FM, FY, KF, MM, MO, 
ND, PO, RS, SF, ZP, and all the memory 
mode commands. 


RETURN Command 


Operation: RETURN 

Code: RETURN 

Syntax: [CR] 

Explanation: RETURN executes commands that are not 


executed immediately on entry of the 
command. For commands that allow re- 
execution, RETURN is used to re-execute the 
previous command. This eliminates the need 
to retype lengthy commands. 


NOTE 
The following commands are not 
reexecuted by a return or redisplayed by 
a line feed: DC, DI, FM, FY, KF, MM, 
MoO, ND, PO, RS, SF, ZP, and all the 
memory mode commands. 
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B.8.2 UTILITY COMMANDS 


The following are Utility Commands: 


KEYBOARD FORMAT Command 


Operation: KEYBOARD FORMAT 

Code: KF 

Syntax: (>) [K] [F] [Address Base] [/] [Data Base] 
(CR] 


Explanation: The KF command sets the address and data 
bases the operator will use in communicating 
-addresses and data. These number bases may 
differ; for example, hexadecimal addresses 
and binary data may be displayed together. 
Default Value - hexadecimal. 


Bases: 0 = hexadecimal 
1 = decimal 
2 = octal 
3 = binary 


CONFIGURATION NUMBER Command 


Operation: CONFIGURATION NUMBER 
Code: CN 
Syntax: (>) [C] [N] [CR] 


Explanation: This command displays the configuration 
number which identifies the software resident 
in the Z29B. 


NIBBLE MODE Command 


Operation: WNiBBLE MODE 

Code: NM 

Syntax: (>) [N] [M] [CR] 

Explanation: This command sets a 4-bit word size to 


override 8-bit programming Paks. Default 
Value - programming electronics word size. 


NOTE 
The word size in effect does not change 
upon entering or exiting remote control. 


BYTE MODE Command 


Operation: BYTE MODE 

Code: BM 

Syntax: (>) [B] [M] [CR] 

Explanation: This command nullifies the Nibble Mode 


command, allowing the programming Pak 
word size to take effect. 
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SIZE MEMORY Command 


Operation: SIZE MEMORY 
Code: SM 
Syntax: (>) (S] [Mj [CR] 


Exnlanation: 


ape tMas rCa eas 


This command causes the terminal to dispiay 
the beginning and ending addresses in RAM, 
added to the address offset in effect. The 
beginning address value is the address-offset. 
The ending RAM address is the beginning 


address plus the available RAM size. 


NOTE 
For the 29B version with 64k bytes RAM: 
If the virtual address offset (see the 
“VM” command) is greater than zero the 
ending address displayed will not show 
the most significant bit(s). This is 
because only the 16 lowest order binary 
bits of the address are shown on the 
display. The operator must add the most 
significant bits which will be equal to “1” 
binary to derive the ending address. 


SELECT EXTERNAL FUNCTION Command 


Operation: SELECT EXTERNAL FUNCTION 

Code: SF 

Syntax: (>) (Sj (Fi [Seiect Code] [CRI 

Explanation: Some Select Codes are associated with the 


programming Pak, and can only be accessed 
when that Pak is installed in the programmer. 
To access those Select Code functions in 
terminal remote control, the Select Code is 
entered after SF. 


SUMCHECK Command 


Operation: SUMCHECK 

Code: Sc 

Syntax: (>) [S] [C] [CR] 

Explanation: This command instructs the programmer to 


compute the sumcheck of all RAM data and 
to display it at the terminal. For example, the 
terminal will display ‘‘“SUM =06FE.” 


NOTE 
lf data in the RAM has been recently 
changed the operator should wait at least 
three seconds before issuing this 
command to insure valid results. 


NO OPERATION Command 


Operation: NO OPERATION 

Code: CC 

Syntax: (>) (Ci [C] [CRI 

Explanation: No operation is performed by the 29B. The 
command may be used in the operating 
program when no action is required. A 
prompt character “>” is displayed. 
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B.8.3 DEVICE COMMANDS 


The following are Device Commands: 


CLEAR DEVICE COUNTER Command 


Operation: 
Code: 
Syntax: 
Explanation: 


CLEAR DEVICE COUNTER 

CD 

(>) [C] [D] [CR] 

The CD command clears the count of the 
number of program operations accumulated 
since power-on, since the last FO command 
was entered at the programmer keyboard, or 
since the last CD command. 


DEVICE SIZE Command 


Operation: 
Code: 
Syntax: 
Explanation: 


DEVICE SIZE 

SP 

(>) [C] [D] [CR] 

This command causes the terminal to print 
the number of words and number of bits per 
word of the device which the programmer is 
configured to program. Addresses are in the 
specified keyboard format. In hex format, for 
example, a 1024 x 8 matrix would be 
displayed as 3FF/8. 


DISPLAY FAMILY & PINOUT Command 


Operation: 
Code: 
Syntax: 


Explanation: 


DISPLAY FAMILY & PINOUT 

FP 

(>) [F] [P] [CR] 

With a Data I/O multi-device pak installed in 
the programmer this command is used to 
display the device Family and Pinout Codes. 
These codes are found in the Pak’s manual. 


SELECT FAMILY & PINOUT Command 


Operation: 
Code: 
Syntax: 


Explanation: 


SELECT FAMILY & PINOUT 

FY 

(F] [Y] [Family Code] [/] [Pinout Code] [CR] 
With a Data I/O multi-device pak installed in 
the programmer this command is used to 
select the device Family and Pinout Codes. 
These codes are found in the Pak’s manual. 


SELECT PINOUT Command 


Operation: 
Code: 
Syntax: 


Explanation: 


SELECT PINOUT 

PO 

(>) [P] [0] [Pinout Code] [CR] 

With a Data I/O multi-device pak installed in 
the programmer, this command can be used 
to change the device Pinout Code when the 
correct Family Code is already selected. These 
codes are found in the Pak’s manual. 
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LOAD Command 


Operation: 
Code: 
Syntax: 


Explanation: 


LOAD (Device to RAM) 

LD 

(>) [C] [D] [Begin RAM Address] [/] 
[Number of Bytes] [/] [Begin Device Address] 
[CR] 

This command causes device data to be 
loaded into programmer RAM. If address 
limits are specified, device data starting at the 
specified device address is loaded into RAM, 
starting at the Begin RAM address and 
continuing until the specified number of bytes 
has been sent. If address limits are not 
specified the entire device data will be loaded 
into RAM. For 4-bit devices, device data will 
be loaded to the low-order nibble in RAM. 
Upon successful loading of data from a part 
the sumcheck of the data loaded is displayed. 


PROGRAM Command 


Operation: 
Code: 
Syntax: 


Explanation: 
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PROGRAM (RAM to Device) 

PG 

(>) (P] [G] [Begin RAM Address] [/] 
[Number of Bytes] [/] [Begin Device Address] 
[CR] 

This command causes an illegal-bit check and 
a blank check of the device before RAM data 
is programmed into a device. If address limits 
are specified, RAM data between those 
addresses is programmed, starting at the 
Begin Device Address. If address limits are 
not specified, the entire device will be 
programmed. For 4-bit devices, the low-order 
nibble in RAM will be programmed into a 
device. The Swap Nibbles command may be 
used previous to the ‘““PG’’ command to move 
data from the high-order nibble of RAM to 
the low-order nibble of RAM, so that it can 
be subsequently programmed by the “PG” 
command. 


If the device to be programmed is non-blank 
the 29B will display on the CRT terminal 
“DEVICE NOT BLANK. S=SKIP.” If the 
operator still wishes to program the part he 
responds by typing “S’’. If not, he will abort 
the command by typing ‘‘ESC” key on 
keyboard. 


If the device cannot be programmed because 
a bit or more is already programmed where it 
should not have been, then an illegal-bit error 
exists. The 29B will display on the CRT 
terminal “ILLEGAL BIT” and a prompt “>” 
to signify the command was aborted and that 
the 29B is ready for another command. 


Upon successfui programming of a part the 
programmer outputs a count of the number 
of programming operations completed. To 


reset this count see the “CD” command. 


rer s 


Pressing the RETURN key repeais the 
Program operation. 


VERIFY Command 


Operation: 
Code: 
Syntax: 


Explanation: 


VERIFY (Device vs. RAM) 

VF 

(>) [V] [Fl] [Begin RAM Address] [/] 
[Number of Bytes] [/] [Begin Device Address] 
[CR] 

This command compares data in a device 
with data in RAM. If address limits are 
specified, verification occurs only within the 
specified number of bytes, starting at the 
specified RAM and device addresses. If 
address limits are not specified the entire 
device data is verified against the RAM data. 


For 4-bit devices, device data will be verified 
against the low-order nibble of RAM. After a 
successful verification, the programmer 
returns a sumcheck for the data verified and 
displays ““VERIFY OK” and a prompt 
character. 


If the device data fails to verify against the 
RAM data the following message is displayed 
on the terminal CRT screen: “PASS 1 
VERIFY ERRORS = NN,” where NN is a 
number denoting the quantity of errors. There 
could also be a “PASS 2 VERIFY ERRORS 

= NN” if errors were only detected on the 
second of the two verify passes. 


Also the address, RAM data and device data 
for each mis-verify location is displayed on 
the terminal’s CRT screen. At the last mis- 
verify location, the sumcheck for the RAM 
data is displayed along with the message 
“VERIFY ERROR.” 
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B.8.4 1/0 COMMANDS 


The following are 1/O Commands: 


ODD PARITY Command 


Operation: 


Code: 
Syntax: 
Explanation: 


ODD PARITY 

OP 

(>) [0] [P] [CR] 

The programmer sets odd parity for output 
data and inspects incoming data for odd 
parity. Default Value—programmer’s parity- 
switch setting. 


EVEN PARITY Command 


Operation: 
Code: 
Syntax: 
Explanation: 


EVEN PARITY 

EP 

(>) [E] [P] [CR] 

The programmer sets even parity for output 
data and inspects incoming data for even 
parity. Default Value— programmer's parity- 
switch setting. 


NO PARITY Command 


Operation: 
Code: 
Syntax: 
Explanation: 


NO PARITY 

NP 

{>} IN] [P] [CR] 

This command instructs the programmer not 
to check input data for parity, and not to set 
parity for output data. Default Value— 
programmer's parity-switch setting. 


DEFAULT PARITY Command 


Operation: 
Code: 
Syntax: 
Explanation: 
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DEFAULT PARITY 

DP 

(>) [D] [P] [CR] 

This command returns the programmer to the 
default parity value, which is the 
programmer's parity-switch setting. 


NULL DEFI 


Operation: 
Code: 
Syntax: 
Explanation: 


NE Command 


NULL DEFINE 

ND 

(>) IN] [D] [Decimal Number of Nulls] [CR] 
This command allows choice of sufficient 


nulls for the terminal to recover at the end of 


a line of output data. Any number from 0 up 


to 254 may be entered. Default Value—1 null. 


A carriage return and a line feed always 


precedes the nulls for null counts values from 


0 to 254. However, a null count of 255 (FF 
hexadecimal) is used to specify a single 


carriage return without a linefeed and without 


any nulls. 


NOTE 


The number of output nulls in effect 
does not change upon entering or exiting 
remote control. 


RECORD S 


Operation: 
Code: 
Syntax: 
Explanation: 


7. 


IZE Command 


RECORD SIZE 

RS 

(>) [R] [S] [Decimal Number of Bytes] [CR] 
This command sets the number of bytes per 
output record for those formats which allow 
variable record lengths. Any number up to 
255 may be entered. Default Value—16 bytes 
per record (8 bytes per record in Fairchild 
Fairbug). 


NOTES 
The record size in effect does 
not change upon entering or exiting 
remote control. 


When you change from one 
translation format to another, the 
record size in effect remains the same, 
unless you change to Fairchild 
Fairbug, which has mandatory 8-byte 
records. 


SELECT ONE STOP BIT Command 


Operation: 
Code: 
Syntax: 
Explanation: 


SELECT ONE STOP BIT 

OS 

(>) [0] [S] [CR] 

This command sets one stop bit for serial 
data transfers. Default Value - programmer's 
stop-bit-switch setting. 
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SELECT TWO STOP BITS Command 


Operation: 
Code: 
Syntax: 
Explanation: 


SELECT TWO STOP BIT 

TS 

(>) [T] [S] [CR] 

This command sets two stop bits for serial 
data transfers. Default Value - programmer's 
stop-bit-switch setting. 


DEFAULT STOP BITS Command 


Operation: 
Code: 
Syntax: 
Explanation: 


DEFAULT STOP BITS 

DS 

(>) [D] [S] [CR] 

This command returns the programmer to the 
stop-bit default value, which is the 
programmer's stop-bit-switch setting. 


TRANSLATION FORMAT Command 


Operation: 
Code: 
Syntax: 
Explanation: 


TRANSLATION FORMAT 

FM 

(>) [F] [MJ] [Control-Format Code] [CR] 
This command selects the translation format 
for serial !/O data transfer. The one digit 
Instrument Control code and the two-digit 
translation-format codes are listed in 
Appendix A. Default Value - ASCII-HEX 
(Space), format code 50. 


NOTE 


The translation format in effect does not 
change upon entering or exiting remote 
control. 


VIRTUAL MEMORY OFFSET Command 


Operation: 
Code: 
Syntax: 
Explanation: 
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VIRTUAL MEMORY OFFSET 

VM 

(>) (V] [M] [Offset] [CR] 

The offset value redefines all programmer 
RAM addresses. Thus, RAM Address 0 
becomes equal to the offset, address 1 
becomes the offset plus 1, address 2 
becomes the offset plus 2, etc. These new 
addresses are used in the Memory Mode, and 
are also used in place of an address offset in 
1/O data transfers. 


Thus for data translation using terminal 
remote control VM has two meanings. First it 
defines the address value of the lowest RAM 
location or the RAM offset. Second it defines 
(and is used in place of) the 1/O address 
offset (equivalent to the port address for 
keyboard operations). However, the |/O 
address offset is undefined and assumes a 
value equal to zero for those formats which 
don’t send address information as part of 
data translation. Therefore, there is effectively 
no !/O address offset regardless of the value 


defined by “VM” for formats such as format 
10 and 11 which do not send address 
information (see Appendix A}. However, even 
for data translation using these formats the 


aQRAT al sail 7 iafi 
VM" command will continue to define the 


address value of the RAM locations. 


The VM can be set greater than 64K for I/O 
translations of 16-bit formats with 5, 6, and 8 
character address fields by entering a slash 
between the high-order and four low-order 
characters of the offset value. 


NOTE 
The 29B version with 64K or RAM is not 
designed to manipulate any virtual 
address defined to be greater than 64K 
(FFFF). Thus if the lowest address 
location is defined by the “VM” 
command to be greater than zero then its 
highest virtual address should logically be 
greater than 64K. However, the 29B 
version with 64K of RAM can not display 
an address field greater than 64K, will 
instead actually display only the 16 least 
significant bits of the address field. 
Moreover an operation which would 
require data to he addressed which is 
greater than 64K will result in an error 
#56 (RAM range error). 


DISABLE TIMEOUT Command 
Operation: DISABLE TIMEOUT 


Code: 
Syntax: 


DT 
(>) [D] [T] [CR] 


Explanation: This command disables |/O timeout. The |/O 


timeout is a time interval (25 seconds) used 
during data translation (either DI, DC, or DO 
commands) during which the 29B will wait for 
data coming in (for DI and DC commands) or 
for the output device not to be busy (for the 
DO command). The timeout will be restored 
only when the programmer is switched ON 
again. 


DATA INPUT Command 


Operation: DATA INPUT 

Code: DI 

Syntax: (>) [D] [1] [Begin RAM Address] [/] [Number 
of Bytes] [CRI 

Explanation: Data originating at a terminai or computer is 
translated (using the selected translation 
format, see ““FM’’ command) into binary data 
which is then stored in RAM at the specified 
address limits. After the input operation is 
complete, the terminal displays the sumcheck 
of all data translated. 


NOTE 
If Binary (format 10) without an arrow- 
shaped leader, DEC Binary (format 11), 
or ASCII Binary data (formats 01 through 
09, 12, 13) with no end code is input 
from a paper tape reader, the “Number 
of Bytes,”’ must be specified, 
corresponding to the length of the tape 
Starting at the first data character. 


NOTE 
Using a “BREAK” or “ESC” key during 
execution of the above command may 
not abort the command if a stream of 
data continues to be output to the 
programmer. 


DATA OUTPUT Command 


Operation: DATA OUTPUT 

Code: DO 

Syntax: (>) [D] [0] [Beginning RAM Address] [/] 
[Number of Bytes] [CR] 

Explanation: This command causes the programmer to 
output RAM data between the specified 
addresses to the terminal or computer in the 
data format previously specified in the FM 
command. With a 4-bit device selected, RAM 
data from the low-order nibble will be output. 
If output is through a tape punch, the tape 
will contain a leader of fifty null characters, 
data in the specified format, then fifty more 
null characters. There is one exception: If the 
null count (defined by the ““ND’’ command) is 
set to a value of FF (hexadecimal) then no 
nulls are sent at the beginning or the ending 
of data translation. After the output operation 
is complete, the terminal displays the 
sumcheck of all data transferred. 


NOTE 


The BREAK or ESCAPE key can be used 
to abort a binary data output operation. 
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DATA COMPARE Command 


Operation: DATA COMPARE 

Code: DC 

Syntax: (>) [D] [C] [Begin RAM Address] [/] 
[Number of Bytes] [CR] 

Explanation: This command is the same as Data Input (DI) 


except that remote data is not transferred - it 
is compared with RAM data. The programmer 
sends to the terminal the sumcheck of all 
data compared. Any failure causes an error 
message to be sent to the terminal. The QB 
command can be used to determine the 
number of non-compare errors. 


NOTE 
lf Binary without an arrow-shaped leader, 
DEC Binary or ASCII Binary data with no 
end code is input from a paper tape 
reader, the “Number of Bytes,” must be 
specified corresponding to the length of 
the tape starting at the first data 
character. 


NOTE 
Using a “BREAK” or “ESC” key during 
execution of the above command may 
not abort the command if a stream of 
data continues to be output to the 
programmer. 


1/0 PARAMETERS Command 


Operation: 1/0 PARAMETERS 

Code: QA 

Syntax: (>) [Q] [A] [CR] 

Explanation: On this command, the programmer outputs 4 


sets of characters: the address offset, the 
translation format, the number of nulls and 
the output-record size currently in effect. The 
display is as follows: 
HARA ORE NNN 


RtAdaS 


Where the above symbols are defined as 
follows: 


AAAA or AAAAAA represents the address 
offset in effect, represented by 4-6 digits 
depending on the keyboard format in 
effect. 


FF represents the translation format in 
effect. 


NNN represents the decimal number of 
output nulls in effect. 


RRR represents the decimal number of 
bytes per output recorded in effect. 
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INPUT COMPARE ERRORS Command 


Operation: INPUT COMPARE ERRORS 

Code: QB 

Syntax: (>) [Q)} [B] [CR] 

Explanation: On this command, the programmer outputs 


the number of misverify errors that occurred 
during an Input (‘DI” or “‘DC”) operation. 


BUFFER-OVERFLOW ERRORS Command 


Operation: BUFFER-OVERFLOW ERRORS 
Code: Qc 
Syntax: (>) [Q] [C] [CR] 


Explanation: On this command, the programmer outputs 
the number of characters received during an 
input “DI or “DC” operation after the 
programmer instructed the terminal to stop 
sending data. 


1/O ERROR STATUS Command 


Operation: {/O ERROR STATUS 
Code: QD 
Syntax: (>) [Q) [D] [CR] 


Explanation: On this command, the programmer outputs 
three sets of characters which give the total 
number of each of these three types of errors 
that occurred during an input (“DI or “DC’”’) 
operation. The display is as follows: 


Where the above symbols are defined as 
follows: 


XX represents the decimal number of 


either: 

1. non-valid characters (Formats 01-03, 5-9, 
12-13). 

2. missing data characters (Formats 30-37 
and 50-58). 

3. non-hex characters (Formats 80-88, 90). 


YY represents the decimal number of 
sumcheck errors. 


ZZ represents the decimal number of parity 
errors. 
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B.8.5 EDITING COMMANDS 


The following are Editing Commands: 


COMPLEMENT MEMORY Command 


Operation: 
Code: 
Syntax: 


Explanation: 


COMPLEMENT MEMORY 

CM ; 
(>) [C] [M] [Beginning Address] [/] [Number 
of Bytes] [CR] 

This command causes the programmer to 
complement RAM contents at the specified 
addresses; that is, all one bits are turned into 
zeros, and all zero bits are turned into ones. 
If no addresses are specified, all RAM data is 
complemented. 


CLEAR ALL RAM Command 


Operation: 
Code: 
Syntax: 
Explanation: 


CLEAR ALL RAM 

CA 

(>) [C] [A] [CR] 

This command clears all RAM memory to 
zeros, whether the programmer is set for 4-bit 
or 8-bit operation. 


SWAP NIBBLES Command 


Operation: 
Syntax: 
Explanation: 


SWAP NIBBLES 

SN 

(>) [S] [N] [CR] 

This command exchanges high-order and low- 
order halves of every word in RAM. 


SPLIT RAM DATA Command 


Operation: 
Code: 
Syntax: 
Explanation: 


SPLIT RAM DATA 

SD 

(>) [S] [D] [Center Point] [CR] 

For 16-bit microprocessor data; complement 
of Shuffle Ram Data (below). After you 
serially input a block of 16-bit data to RAM 
(each sequential pair of 8-bit bytes 
representing a 16-bit word), the SD command 
“splits’’ the 16-bit block into two adjacent 
8-bit blocks, separated by the specified center 
point. The split stores the even-numbered 
8-bit bytes of each byte pair in sequence from 
address 0 to the center point; odd-numbered 
bytes are stored in sequence at addresses 
beginning at the center point. The 
reorganized data occupies the same original 
block in RAM. 
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You can then program each block of data 
into an 8-bit device, and the two devices can 
be addressed in parallel (while in use) to 
deliver 16-bit words to the processor. 


wl 


Typically 


ically, the center point will equal the 
number of words in the 8-bit device to be 
programmed. In any event, it must meet two 


requirements: 
1. It must be a power of 2. 


2. It must be less than or equal to half the 
size of the resident RAM. 


Center-point default value—RAM midpoint. 


SHUFFLE RAM DATA Command 


Operation: 
Code: 
Syntax: 
Explanation: 


SHUFFLE RAM DATA 

SH 

(>) [S] [H] [Center Point] [CR] 

For 16-bit microprocessor data. Complement 
of Split RAM Data, this command merges 
blocks of data which met at the specified 
center point address. Two 8-bit devices are 
first loaded next to each other in RAM, 
beginning at address 0, to create the two 
blocks, which are then merged for serial 
ifanster. The cenier-point Must be a powe;# ot 
2 between 0 and RAM midpoint. Center-point 
default value—RAM midpoint. 


RAM-RAM BLOCK MOVE Command 


Operation: 
Code: 
Syntax: 


Explanation: 
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RAM-RAM BLOCK MOVE 

BL 

(>) [B] [C] [RAM Source Address] [/] 
[Number of Bytes] [/] [RAM Destination 
Address] [CR] 

This command instructs the programmer to 
move the specified number of bytes beginning 
at the RAM Source Address to a new RAM 
location beginning at the RAM Destination 
Address. 


ENTER MEMORY MODE (at address) Command 


Operation: ENTER MEMORY MODE (At Specified 
Address) 

Code: MM 

Syntax: (>) [M] [M] [Valid Address] [CR] 

Explanation: The terminal enters the Memory Mode at the 


specified ‘’valid address.” A valid address is - 
defined as an address within the word limits 
of virtual memory expressed in the number 
base previously selected with the KF 
(Keyboard Format) command. If an address is 
not given prior to RETURN, the starting 
address of virtual memory is assumed default 
value equals @. The carriage return causes a 
display of the address and the data at that 
address. Also the curser stops just past the 
data field awaiting further memory mode 
commands. See the following example: 


EXAMPLE: Entering memory mode using the 
default value for virtual memory of 9. 


keystrokes: [| 


display: 
ue HH on 


Where 0000 is the address 
HH is the hexadecimal value of the 
data 
is the cursor used as a prompt 
for a Memory Mode Command 
(see section B.8.6). 


ENTER MEMORY MODE (at last address) Command 


Operation: ENTER MEMORY MODE (At Last-Displayed 
Address) 

Code: MO 

Syntax: (>) [M] [0] [CR] 


Explanation: The terminal enters the Memory Mode at the 
last-displayed address. Otherwise, this 
command is the same as the “MM” 
command. 
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B.8.6 MEMORY MODE COMMANDS 


In the Memory Mode, RAM data is displayed and 
manipulated. The printer or CRT displays two fields - 
address and data - and the print head or CRT cursor 
indexes to the right of the data field awaiting Memory 
Mode commands. The addresses displayed are virtual 
addresses, in other words, the beginning of RAM is 
defined by whatever value was issued by the “VM” 
command. Addresses below this value are undefined. 


To enter the memory mode use either the “MM” or “MO” 
command (see subsection B.8.5). To exit the memory 
mode use the memory mode “E”’ command. 


The following are memory mode commands: 


DISPLAY NEXT ADDRESS Command 


Operation: DISPLAY NEXT ADDRESS 
Code: N 
Syntax: (Address) (Data) [N] 


Explanation: Each N keystroke displays the next higher 
address and the data at that address. 


DISPLAY LAST ADDRESS Command 


Operation: DISPLAY LAST ADDRESS 
Code: L 
Syntax: (Address) (Data) [L] 


Explanation: Each L keystroke displays the next lower 
address and the data at that address. 


JUMP ADDRESS Command 


Operation: JUMP ADDRESS 

Code: d's 

Syntax: (Address) (Data) [J] [Valid Address] [CR] 

Explanation: This command allows the operator to jump 
from the currently displayed address to the 
specified valid address. The default address is 
the Virtual Memory Offset. 
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CHANGE DATA Command 


Operation: 
fr. wt. 
VLoae. 


Syntax: 


Explanation: 


CHANGE DATA 

fo 

uw 

(Address) (Data) [C] [Valid Data] [CR] or 
{SPACE} 

This command changes the displayed data to 
the specified valid data. The RETURN key 
causes the command to execute once. To 
execute the change command more than 
once use the SPACE BAR instead of the 
RETURN key. This is the same as pressing 
RETURN and “C” again; thus, valid data 
must be entered each time. 


EXAMPLE: Change DD to EE at address 
004. 


BEFORE AFTER 

Ad- Data Key- Address Data 
dress strokes 

000 AA 000 AA 
001 BB 001 BB 
002 cc 002 CC 
003 DD 003 DD 
004 DD C EE [CR] 004 EE 


INSERT DATA Command 


Operation: 
Code: 
Syntax: 


Explanation: 


INSERT DATA 

| 

(Address) (Data) [I] [Valid Data] [CR] or 
[SPACE] 

This command places valid data into the 
displayed address and moves the old data and 
all subsequent data to the next higher 
address. The RETURN key causes the 
command to execute once. To execute an 
Insert command more than once use the 
SPACE BAR instead of the RETURN key. 
This is the same as hitting RETURN and “I” 
again. Thus, valid data must be entered each 
time. 


EXAMPLE: Insert EE into address 002. 


BEFORE AFTER 

Ad- Data Key- Address Data 

dress strokes 

000 AA 000 AA 

001 BB 001 BB 

002 CC IEECR 002 EE 

003 DD 003 CC 
004 D 
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DELETE DATA Command 


Operation: 


Cada: 
vVvuus. 


Syntax: 


Eynianatinn: 
explanation: 


DELETE DATA 
D 


(Address) (4Data) [D] [CR] or [SPACE] 

This command causes data ai the disniayed 
address to be removed from memory, and all 
following data is moved down one location 
(toward lower addresses). The last RAM 
memory location is loaded with zero. The 
RETURN key causes the command to execute 
once. To execute more than once use the 
SPACE BAR instead of the RETURN key. 
This is the same as entering RETURN and 
“D” again. 


EXAMPLE: Delete EE into address 002. 


BEFORE AFTER 
Ad- Data Key- Address ___ Data 
dress strokes 

000 AA 000 AA 

001 BB 001 BB 

002 EE DCR 002 CC 

003 cc 003 DD 
004 DD 


REPEAT DATA Command 


Explanation: 
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REPEAT DATA 

R 

(Address) (Data) [R] [Valid Data] [Number 
of Locations] [CR] 

This command places valid data into the 
specified number of memory locations 
beginning at the displayed address. 


EXAMPLE: Repeat EE three times starting 
at address 002. 


BEFORE AFTER 

Ad- Data Key- Address Data 
dress strokes 

000 11 000 11 
001 22 001 22 
002 33 REE/3CR 002 EE 
003 44 003 EE 
004 55 004 EE 
005 66 005 - 66 
006 77 006 77 


FILL DATA Command 


Operation: 
Code: 
Syntax: 
Explanation: 


FILL DATA 

F 

(Address) (Data) [F] [Valid Data] [CR] 

This command causes valid data to be placed 
in each RAM address from the displayed 
address to the end of RAM. The terminal 
then exits the memory mode and displays the 
prompt character (>). 


FILL UNPROGRAMMED DATA Command 


Operation: 
Code: 
Syntax: 
Explanation: 


FILL UNPROGRAMMED DATA 

U 

(Address) (Data) [U] [CR] 

This command fills memory from the 
displayed address to the end of RAM with 
no-program information. That is, if the 
programmer is configured to program VOH 
devices, remaining memory is filled with 
logical ‘’0’’ (low state). Likewise, if the 
programmer is set to program VOL devices, 
remaining memory is filled with logical ‘’1” 
(high state). The terminal then exits the 
Memory Mode and displays the prompt 
character (>). 


SEARCH DATA Command 


Operation: 
Code: 
Syntax: 


Explanation: 


SEARCH DATA 

BS) 

(Address) (Data) [S] [Valid Data] [/] 
[Beginning Address] [/] [Number of Bytes] 
[CR] 

This command displays all locations 
containing the specified valid data. Entry of 
the beginning address and number of bytes is 
optional. If addresses are entered, the display 
is bounded by those address limits. If no 
addresses are specified, all RAM locations 
containing the entered valid data are 
displayed. 
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SUBSTITUTE DATA Command 


Operation: 
Code: 
Syntax: 


Explanation: 


SUBSTITUTE DATA 

B 

(Address) (Data) [B] [Valid Data 1] [/] [Valid 
Data 2] [/] [Beginning Address] [/] [Number 
of Bytes] [CR] 

This command causes “’Valid Data 2"’ to 
replace ‘‘Valid Data 1” within the specified 
address limits. If no addresses are specified, 
substitution occurs in all of RAM. 


LIST DATA Command 


Operation: 
Code: 
Syntax: 
Explanation: 


LIST 

T 

(Address) (Data) [T] [Number of Locations] 
This command causes the terminal to list the 
specified number of RAM addresses and their 
data starting with the displayed address. 


ESCAPE MEMORY MODE Command 


Operation: 
Code: 
Syntax: 
Explanation: 
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ESCAPE MEMORY MODE 

E 

(Address) (Data) [E] 

This command causes exit from the Memory 
Mode. The terminal displays a prompt 
character (>) and will then recognize two- 
character commands. The ESC key can also 
be used for this purpose, but if ESC is 
pressed while processing is occuring, data in 
scratch pad buffers will be lost. Therefore, it 
is recommended that E always be used to 
escape the Memory Mode. 
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29B/HANDLER INTERFACE 


C.1 1 


TRODUCTION 
This appendix describes now io sate ie 
Handler UniPak™ and a commercially 


and hacir 
aimiMm wuviw 


sete 238 with the 
lable handler. 
Oneration of the 


vee 


Covered are componenis, setup, 
system. For more detailed information, consult your 
handler and Handler UniPak™ manuals. 


C.2 COMPATIBILITY 


The Handler UniPak™ will currently interface wni: both the 
Delta and Micro Component Technology (MCT) handlers. 
An Exatron handler is also compatible with the 29B, but 
does not require the Handler UniPak™ or the handler port. 
Instead, the Exatron handler interfaces with the 29B 
directly via computer remote control (CRC) and with the | 
standard programming Paks. (Exatron supplies the interface 
package with the handler.) A third type of handler 
interface, also not requiring the Handler UniPak™, 
interfaces via the 29B’s handler port and standard 
programming Paks (see section C.3). 


C.3 29B HANDLER PORT INFORMATION 


The following information is provided for 29B users who 
are making their own interface. Figure C-1 shows the port 
pin numbers; table C-1 defines the function of each. Figure 


C-1 


C-2 illustrates the handler control timing. To prevent device 
oscillation or other errors, it is recommended that the cable 
connecting the handler device contacts to the programming - 
Pak socket be shielded and minimal length. 


PIN 12 


PIN 1 


\_ 
| - PIN 24 PIN 13 


Figure C-1. 29B Handler Port Pin Assignment 
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18, 19, 20 


Table C-1. Handler Interface Connector Pin Assignment 


Signal Mnemonic 


Ground 
+5V 


Ground 


Illegal Bit Bin 


Pass Bin 


Strobe 


Ground 


Start 


ID1, IDO, ID2 


Programming Error Bin 


Verify Error Bin 
Spare Bin 


Ground 


Description 


Connected to the programmer's +5V logic supply. Available for external 
use if required (200mA max.). 


Signal lines for selecting the appropriate handler bin. These open- 
collector outputs go to ground for 2 milliseconds when selected by the 
programmer. 


Signal used for handlers that need a strobe as well as a binning signal. 
This open-collector output goes to ground coincidentally with any of the 
four binning signals. 


This input is internally pulled to +5V and should be grounded to inform 
the programmer of when a device is in place in the handler. This signal 
should not go high again until 1 millisecond after the previous binning 
signal goes high. 


These inputs inform the programmer what is connected to the port. If 
pins 18, 19, 20 are all high, the 29B identifies the port as being not con- 
nected. If pin 19 is low, and 18 and 20 are high, the port is identified as 
being connected to a handler. 


Signal lines for selecting the appropriate handler bin. These open- 
collector outputs go to ground for 2 milliseconds when selected by the 
programmer. 


For future use. 
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NS SR BL SS A 


i I 
PROG ERR BIN(21) +5V —— = FOR HANDLERS 
GND | WITH LESS THAN 
4 INPUTS 


f 
START WY +5v —— 
(FROM HANDLER) 

GND 


| PROG OR VERIFY TIME 


< 60 MS MIN ——— >| 


| 
| | 
PASS BIN +5V a 
GND | 
| | | 
| 


| 
| 
| ONE OF 4 
| SIGNALS GOES 


ILL BIT BIN (3) +5V ee 
GND | LOW FOR EACH 


DEVICE TESTED 


OUTPUTS MAY 


MF ANPREN AB 
BE VInbe-wit 


STROBE GOES 
LOW SIMUL- 
. TANEOUSLY 


STROBE (1) +5V WITH THE 
APPROPRIATE 
BIN SIGNAL, 
USED WITH 
DELTA 


HANDLERS 


Figure C-2. Handler Control Signal Timing Diagram 
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C.4 SYSTEM COMPONENTS 


As shown in figure C-3, the 29B/handler system consists 
of 1) the 29B Programmer, 2) the Handler UniPak™, 3) a 
handler compatible with the 29B, 4) a performance board, 
which configures the system to the particular device to be 
programmed, and 5) a terminal (optional). Also included in 
the system are the various cables that transmit data 
between components of the system. 


TERMINAL OR COMPUTER 
(OPTIONAL) 


C.5 PERFORMANCE BOARD SELECTION 


The Performance Board configures the 29B/handler system 
to the particular device the user wishes to program. For all 
but 16-pin devices, select the board that has the same 
number of pins as the device you want to program. 


For the 16-pin devices, there are two performance boards: 
one for 4-bit output devices and one for 8-bit output 
devices. 


HANDLER* 
(COMMERCIALLY 
AVAILABLE) 


PERFORMANCE 
BOARD (AT BACK) 


HANDLER 
UniPak™ 


29B UNIVERSAL 
PROGRAMMER 


D 


Loe 


*Delta handler 


\ is shown here. 


Figure C-3. The 29B/Handler System 
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C.6 MCT HANDLER SETUP 


NOTE 
The Delta handier does not require that 


any of its circuit boards be altered. This 
section refers only to the MCT handler. 


Setting up the MCT handler fer use with the 29B requires 
two procedures: 1) Altering the Opto-Interface Board and 
2) setting the binning switches. These procedures are 
described in the MCT handler interface kit manual, 
(10-950-0102-001), and in section 1 of the MCT handler 
manual. 


C.7 SYSTEM SETUP 


This section of the appendix describes how to set up the 
29B with a handler. Although the Delta and MCT handlers 
do not look the same, system setup is similar. Following is 
a list of the procedures which set up the components of 
the system for operation: 


e Installing the Handler UniPak™ in the 29B (see section 2 
of this manual for procedure) 


e Connecting the Handler UniPak™ to the performance 
board (section C.7.1) 


e Installing the nerfarmance hoard to the handler {sectian 
nstanng the performance Dpoare to tne nancier (section 


C.7.2) 


e Connecting the 29B control cable to the handler (section 
C.7.3) 


¢ Connecting a computer or terminal to the 29B (section 
C.7.4). 


To set up the 29B/handler system, refer to figures C-4 


CONNECTOR 
TABS 


— ae 
EE Pa 
wy 
PERFORMANCE ea a 
BOARD 


CONNECTOR 


Li wm: Oo ana falla.e. tha men annd cen ere poe ee rem LN 
ini ugh C-6 anda Touow iné proceaures given i 


C.7.1 CONNECTING THE HANDLER UNIPAK™ TO 
THE PERFORMANCE BOARD 


The Handler UniPak™ connects to the performance board 
via a 50-pin ribbon cable. The cable/performance board 
functions much like a socket adapter, sending the 
programming signals to the handler. 


To connect the cable, proceed as follows: 


1. Ensure that the connector tabs on the top of the 
Handler UniPak™ are snapped out (see figure C-4). 


2. With the colored sidestrip (indicating pin 1) of the cable 
on the left, insert the 50-pin ribbon cable into the 
Handler UniPak™’s connector. 


3. Ensure that the connector tabs on the Handler UniPak™ 
are now snapped in. 


NOTE 
Pin 1 is marked on both the ribbon cable 
and the connector. On the Handler 
UniPak™’s connector, the pin designator 
is on the underside and to the left {see 
figure C-2). 


4. Ensure that the connector tabs on the performance 
board are snapped out (see figure C-4). 


5. Insert the 50-pin ribbon cable into the connector on the 
performance board. Ensure that the colored sidestrip 
(indicating pin 1) of the cable is on the same side as pin 
1 indication on the performance board. Ensure that the 
connector tabs are now snapped back in. 


HANDLER 
UniPak™ 


Figure C-4. Connecting the Handler UniPak™ and Performance Board 
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C.7.2 INSTALLING THE PERFORMANCE BOARD C.7.3 CONNECTING THE 29B TO THE HANDLER 


To install the performance board in the handler, fit the pins 
on the handler into the holes on the performance board. 
Four standoffs provide a secure physical attachment. See 
figures C-5 (MCT handler) and C-6 (Delta handler) for an 
illustration of the attachment procedure. 


The handler connects to the 29B via a digital control 
interface cable. This cable provides handler control, 
including binning commands. See figures C-7 (MCT 
handler) and C-8 (Delta handler) for an illustration of the 
procedure. 


wT i = SOCKET 
PERFORMANCE =—— “fo oF 
BOARD 


Figure C-5. Installing the Performance Board-MCT Handler 
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PERFORMANCE 
BOARD 


SOCKET 


CAPTIVE SCREWS 


Figure C-6. Installing the Performance Board—Delta Handler 


C.7.4 CONNECTING A COMPUTER OR TERMINAL ~ C.8 POWER UP 
TO THE 29B 

Commands can be issued to the 29B via a compuier or CAUTION 

terminal using Computer Remote Control (CRC). To Voltage transients can damage a 

operate the 29B via computer, the user will have to provide device. Be sure the performance 

special interface software. If you wish to perform board and the handler are free of 

operations with the system using a computer or terminal, devices before you apply power to 

connect an RS232C transmission cable between the 29B the system or before you install or 

and the computer or terminal. See section 2.5 of this remove the Handler UniPak™. 

manual for cable installation details, and section 3.9.1 for 

more intermation:on CRC. To power up the system, follow the procedures given in 
this manual (sections 2.4 and 3.2.2) and the handler’s 
manuals. 

C-7 
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DIGITAL CONTROL 
INTERFACE CABLE 


HANDLER 
PORT 


Figure C-7. Handler/Programmer Connection— MCT Handler 


DIGITAL CONTROL 
INTERFACE CABLE 


HANDLER 
PORT 


Figure C-8. Handler/Programmer Connection—Delta Handler . 
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C.S BASIC DATA TRANSFER OPERATIONS 


The basic operations that can be accompiished with the 
29B/handler system are: 


load the 29B’s RAM with master device data 
(section C.9.5) 


program devices with the 29B’s RAM data 
(section C.9.6) 


verify the 29B’s RAM data against device data 
(section C.9.7) 


These operations may be performed on the handler from 
either the 29B’s keyboard or via CRC. This section 
describes operational setup and basic data transfer 
operations that are unique to the 29B/handler system. A 
more detailed discussion of these data transfer operations 
can be found in section 3 of this manual. 


C.9.1 ENTERING CRC MODE (Optional) 


t# wri 

ist yvu aré yyy 
perform operations with the system, enter select code F1 
on the 29B to enter CRC mode. 


to use a comnuter or a terminal to 


MOY DH Vues: 


To exit CRC, send the “Z’’ return command, or press any 
mode key on the 29B’s keyboard. See section 3.9.1 of this 
manual for a more detailed discussion of the CRC format. 


There are two remote handler commands specific to 
computer remote control. A description of these 
commands is given in table C-2. 


Table C-2. Handler-Specific Commands (CRC Mode) 


COMMAND DESCRIPTION 


% 


This command puts the programmer 
into a waiting state until the handler 
indicates a start condition or the 
operator presses the START key on the 
29B. Once the start condition has been 
received by the 29B, it will output a 
prompt ‘’>’’ symbol to the serial port 
and wait for another command. 


This command instructs the handler to 
distribute programmed and verified 
devices to the number *’n’’ bin, where 
“n’”’ is an integer from 1 to 4. 
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C.9.2 ENTERING FAMILY AND PINOUT CODES 


pinout codes of the devices you wish to program. The 
codes may be entered from either the 29B’s keyboard or 
the terminal. Check the device table in section 1 of the 
Handler UniPak™ manual and locate the two-digit family 
and two-digit pinout codes of the device you wish to 
program. To enter the family and pinout codes into the 
system, follow the procedures given in section 3.4.1 of this 
manual. After a family and pinout code has been entered, 
it will remain in effect until the user changes it or power to 
the 29B is shut off. 


C.9.3 DEVICE INSERTION 


Devices may be placed into the 29B/handler system at two 
locations: 1) the performance board, and 2) the top of the 
handler. 


If you want to load the 29B’s RAM with a master device’s 
data, or if you want to verify the 29B’s RAM data with 
master device data, insert a device into the performance 
board’s device socket. See section 3.4.2 of this manual for 
device insertion procedure. 


Insert devices at the top of the handler if you want to 
program a device({s) or verify preprogrammed devices}. 
When inserting devices into the Delta handler, insert pin 1 
(notched end) of the device first. When using the MCT 
handler, insert pin 1 last. Devices inserted backward will 
cause a backward device error to display on the 29B 
keyboard. 


C.9.4 BINNING CONTROL 
Front Panel Control 


When programming or verifying devices from the front 
panel, binning controls are defined as follows: 


Bin 1: Device passes 

Bin 2: Device fails— illegal bit 

Bin 3: Device fails—failure during programming 

Bin 4: Device fails—failed to verify after programming 
NOTE 


The Delta handler sends both program 
and verify failures to bin 3. 
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CRC Mode 


When operating the handler via CRC, information regarding 
the status of an operation (verify or program) can be 
obtained from the 29B. Based on this status information, 
the user can then bin the device(s) using the ‘‘!"’ 
command. For example, to send a device to bin 2, you 
would enter 2![CR] from the terminal’s keyboard (where 
[CR] denotes a carriage return). In general, you would send 
a binning command after each device has been 
programmed or has failed an operation. See section 3.9 of 
this manual for more information on CRC. 


C.9.5 PREVENTING NONBLANK DEVICES FROM 
BEING PROGRAMMED (Select Code B4) 


To prevent the system from programming nonblank 
devices, enter the ‘‘nonblank fail’ select code B4 from the 
29B’s keyboard. This code, when enabled, will prevent you 
from programming over parts that already contain data. 
Parts that are nonblank will go to bin 2, and an illegal bit 
error message will display on the 29B’s keyboard. 


NOTE 
When six devices in a row fail for the 
same reason, the system will shut down, 
and the sixth device will remain in the 
handler. It may then be binned either 
manually or via CRC. 


Once the “‘nonblank fail’’ code is set, the only way to 
disable the code is to shut off the 29B’s power. See 
section 3.8.5 of this manual for the key sequence that 
enables this function. 


C.9.6 LOAD RAM WITH MASTER DEVICE DATA 
Front Panel Control 


To load the 29B’s RAM with data from a master device, 
follow the procedure given in section 3.6.1 of this manual, 
with one exception: 


Step 6 of the procedure is device insertion. For this step, 
insert the master device into the performance board's 
socket. 


CRC Mode 


To load the 29B’s RAM with data from a master device, 
proceed as follows: 


1. Insert the master device into the performance board's 
socket (see section 3.4.2 for insertion discussion). 


2. Issue the family and pinout codes for the device using 
the ‘‘@” command if they are not already entered. See 
section 3.9.1 for details. 


3. Issue the Load command: “LICR]”. 


4. The 29B will respond with one of three characters: 
">" “E" or 2", See section 3.9.1 for details on CRC. 


C.9.7 PROGRAM DEVICE(S) WITH 29B RAM DATA 
Front Panel Control 


To program device(s) with data from the 29B’s RAM, 
proceed as follows: 


1. Set up the handler for the type of devices to be 
programmed (set device width, binning controls, etc.). 


2. Insert the device(s) into the top of the handler. See the 
handler manual for details on device insertion. 


3. Start the handler. 


4. Perform the “Program Device with RAM Data” 
procedure given in section 3.6.3 of this manual, with 
one exception: Step 6 calls for device insertion. Ignore 
this step, since the devices to be programmed are 
already in the handler. 


NOTE 
Devices will be automatically 
programmed or failed as long as the 
handler continues to feed them. The 
programmed or failed devices will be 
automatically binned as described in 
section C.9.4. 


CRC Mode 


To program device(s) with data from the 29B’s RAM while 
in CRC mode, proceed as follows: 


1. Set up the handler for the type of devices to be 
programmed (set device width, binning controls, etc.). 


2. Insert the device(s) into the top of the handler. See 
the handler manual for details on device insertion. 


3. Start the handler. 


4. Issue the family and pinout codes for the device, 
(using the ‘‘@’’ command) if they are not already 
entered (see section 3.9.1 for details. 


5. Issue the “’T’ command for an illegal-bit check and 
give the ‘‘B’’ command for blank check. Issue binning 
signals in case of error using the “!’’ command. 


6. Issue the Program command: “‘P[CR]’’. 


7. The 29B programmer will respond with one of three 
characters: >", “F’ or “‘?’", See section 3.9.1 for 
details on CRC. 


8. Issue a binning command (1!, 2!, 3! or 4!) to bin the 
device. 


9. If the %” function has been enabled, wait for the 
29B to issue a “>” prompt. If this function is not 
being used, wait until the next device is ready. 


10. Repeat steps 5 through 9 until all devices have been 
programmed. 
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C.9.8 VERIFY DEVICE’S DATA WITH 29B 
RAM DATA 


Front Panel Control 


To verify device(s) with data from the 29B’s RAM, proceed 


as follows: 


1. Set up the handler for the type of devices to be verified 
(set device width, binning controls, etc.). 


2. Insert the device(s) into the top of the handler. See the 
handler manual for details on device insertion. 


3. Start the handler. 


4. Perform the “Verify Device Data with 29B RAM Data’’ 
procedure given in section 3.6.6 of this manual, with 
one exception: Step 6 calls for device insertion. Ignore 
this step, since the devices to be verified are already in 
the handler. 


NOTE 
Devices will be automatically verified or 
failed as long as the handler continues to 
feed them. The verified or failed devices 
will be automatically binned as described 
in section C.9.4. 


CRC Mode 


To verify device(s) with data from the 29B’s RAM while in 
CRC mode, proceed as follows: 


1. Set up the handler for the type of devices to be verified 
(set device width, binning controls, etc.). 


C-11 


2. Insert the device(s) into the top of the handler. See the 
handler manual for details on device insertion. 


3. Start the handler. 


- 


. issue ihe family and pinout c 
the ’“@" command) if they are not already 
section 3.9.1 for details). 


5. Issue the Verify command: ‘‘V[CRI]’’. 


6. The 29B programmer will respond with one of three 
characters: ‘’>", “‘F’’ or ‘2’. See section 3.9.1 for 
details on CRC. 


7. Issue a binning command (1!, 2!, 3! or 4!) to bin the 
device. 


8. If the ““%” function has been enabled, wait for the 29B 
to issue a “>” prompt. If this function is not being 
used, wait until the next device is ready. 


9. Repeat steps 5 through 8 until all devices have been 
verified. 


C.10 OTHER COMMANDS 


Commands other than the Load, Program and Verify 
mentioned in this appendix operate in the same way for 
handler operation as they do for non-handler operation. 
See section 3 of this manual for key sequences and 


£_- anther amaretinensn 
Of OInGr Gperations. 
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Glossary 


address field. A set of characters used with some data 
translation format, which defines the address of the next 
data byte. 


address offset. A value subtracted from addresses during 
input translation and then added to addresses during 
output translation. 


begin device address. The first device address from 
which or to which data is being transferred. 


begin RAM address. The first address of the programmer 
data RAM from which or to which data its to be 
transferred. 


blank check. A test performed by a programmer to detect 
the presence of any programmed bits. A device with no 
programmed bits is “‘blank.”’ 


block size. The hexadecimal number of bytes to be 
transferred in a data transfer. 


bootstrap. The basic software routine which performs 
initial power-up machine checks and prepares the machine 
to receive and respond to operating system instructions. 


configuration number. A 4-digit hex number that 
identifies the software revision level of the programmer. 


data translation format. Form in which the translator 
software accepts input data and transmits output data. 


default value. The value the unit uses for a parameter 
unless the operator specifies another value. 


device. Any PROM, PAL, EPROM, EEPROM, or pro- 
grammable logic part. 


end code. Character in a data translation format which 
signals the completion of a data transfer. 


error code. A code which signals specific errors to the 
operator. 


Family and Pinout Codes. Two-digit codes used by some 
Data I/O programming modules to identify programming 
variables including pinout, address limit and programming 
algorithms. 


generic family. Devices of different memory size 
developed by a manufacturer that require the same 
programming voltages, currents, and timing relationships. 
They can be programmed by the same programming 
module. 


handshaking. The required sequence of signals for 
communication between two units. The !/O bus protocol 
for a unit defines its handshaking requirements. This is 
especially true for asynchronous I/O systems in which each 
signal requires a response to complete an !/O operation. 


illegal-bit test. A test performed by a programmer to 
detect the presence of any programmed bits of incorrect 
polarity (illegal bits). 


mode. A software routine in a machine, characterized by a 
specific automatic sequence of steps. 


nibble. One half of an 8-bit byte. 


programming module. Generic term for Data I/O 
Programming Pak, Program Card Set, UniPak, Gang 
Module, FPLF Pak, MOS Pak, IFL Pak, and other 
programming electronics. 


record size. The number of bytes printed on a line of a 
teletype or other printer; or the number of bytes printed on 
a paper tape before another address field is printed. 


scratch pad memory. The internal RAM memory used by 
the processor for performing calculations. 


select function. A two-digit hex number used to specify 
data translation formats, serial interface operations, or 
certain RAM data manipulations. 


start code. Character in a data translation format which 
signals the beginning of a data transfer. 
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Giossary (Continued) 


the rules of simple addition and usually expressed as a 
four-digit hex number; any carry from the most significant 
bit or digit is discarded. A sum-check is used to verify the 
integrity of data transfers. 


10000100 
11000001 
01100010 
00100100 


0000 0001 1100 1011 


I 


a 
T 


Sum-check in Sixteen-bit binary 
| hexadecimal notation sum-check | 


Sample Sum-check Calculation 


waveforms (programmable). The graphical representation 
of the timing and magnitude of programming pulses. If the 
programming waveforms are not kept within tolerance, 
programming yield is jeopardized. 


word limit. The highest address in a device. For example, 
the word limit of a 1Kx8 device is 1K (or hex 3FF). 


Synonymous with address limit. 


word width. The number of bits in a byte or word (4 or 8). 
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Abbreviations 


The following is a list of abbreviations commonly used in Data I/O Instruction manuals. 


A, - address line 4 

ADDR - address 

BC - bin count, number of bins 

BR - bridge rectifier 

C - capacitor 

CE - Chip Enable 

Clk - clock 

Clk. Inh. - clock inhibit 

Cntl. - control 

Cont. - control 

CR - diode 

CTS - Clear To Send 

D, - data line 5 

DAC - Digital to Analog Converter 

DC - division count, number of partitions 
DCD - Data Carrier Detect 

DCU - Data I/O Data Control Unit 

DI, - data input 2 

DIR - Directory 

DO, - data output 2 

DS - display 

DSR - Data Set Ready 

DTR - Data Terminal Ready 

DVM - digital voltmeter 

Emul - emulate 

ERR - error 

ESC - escape 

F - fuse 

FC - Translation Format Code 

FFPP - Family Code (FF) and Pinout Code (PP) 
FIP - Flourescent Indicator Panel 

FPGA - Field Programmable Gate Array 
FPLA - Field Programmable Logic Array 
FPLS - Field Programmable Logic Sequencer 
FPRP - Field Programmable ROM Patch 
FRME - frame 

Fwd. - Forward 

Gnd. - Ground 

HLT. - Halt 

HV - high voltage 

ID, - identification line 4 

IFL - Integrated Fused Logic 

1/O - Input/Output 

IRQ - Interrupt Request 
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J - jack or connector 


JP - jumper 
K - relay 
LIM - limit 


LSB - Least Significant Bit 

LSD - Least Significant Digit 

MSB - Most Significant Bit 

MSD - Most Significant Digit 

NMI - Non-Maskable Interrupt 

NO CONT SECT - No Contiguous Sector 

Oper. - operate 

PA, - programmer address line 15 

PAK - programming module 

PCS - Program Card Set 

PD, - programmer data line 6 

PN - Part Number 

PR/OE - Preset/Output Enable 

Prog - Program 

Prog. Pulse - Program Pulse 

PROM - Programmable Read Only Memory 

Q - transistor 

R - resistor 

RAM - Random Access Memory 

Read Inh. - Read Inhibit 

Rec. - receive 

Rev. - reverse 

RP - resistor pack 

RST - Reset 

R/W - Read/Write 

RX - Receive Data 

S - switch 

TOR - Turn On Reset 

TX - Transmit Data 

U - integrated circuit device 

Vef2 - the “AND"-ing of the Valid Memory Address line 
and the phase 2 line 

Ver. A - Verify pass A 

Ver. B - Verify pass B 

VFY - verify 

VMA - Valid Memory Address 

VR - Voltage Regulator 

VreF - Voltage Reference 

W/L - Word Limit 

Write Inh. - Write Inhibit 
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Cross-Reference Chart of Number Bases 


Standard 
Binary Octal Hexadecimal Decimal Abbreviation 

0000 0 0 0 

0001 1 1 1 

0010 2 2 2 

0011 .3 3 3 

0100 4 4 4 

0101 5 5 5 

0110 6 6 6 

0111 i 7 7 

1000 10 8 8 

1001 11 9 9 

1010 12 A 10 

1011 13 B 11 

1100 14 Cc 12 

1101 15 D 13 

1110 16 E 14 

1111 17 F 15 

0001 0000 20 10 16 

0010 0000 40 20 32 

0100 0000 100 40 64 

1000 0000 200 80 128 

0001 0000 0000 400 100 256 

0010 0000 0000 1000 200 512 
0100 0000 0000 2000 400 1,024 1K 
1000 0000 0000 4000 800 2,048 2K 
1100 0000 0000 6000 Coo 3,072 3K 
0001 0000 0000 0000 10000 1000 4,096 4k 
0001 0100 0000 0000 12000 1400 5,120 5K 
0001 1000 0000 0000 14000 1800 6,144 6K 
0001 1100 0000 0000 16000 1C00 7,168 7K 
0010 0000 0000 0000 20000 2000 8,192 8K 
0010 0100 0000 0000 22000 2400 9,216 9K 
0010 1000 0000 0000 24000 2800 10,240 10K 
0100 0000 0000 0000 40000 4000 16,384 16K 
1000 0000 0000 0000 100000 8000 32,768 32K 
0001 0000 0000 0000 0000 200000 10000 65,536 64K 
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ASCII & IEEE Code Chart 


KEY 
13 


OCTAL EQUIVALENT 


ASCII 
CONTROL 
CHARACTER 


VT HEXADECIMAL 


EQUIVALENT 


DECIMAL 
EQUIVALENT 


B 1\ 
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ASCII & IEEE Code Chart 
(Continued) 


| | | NUMBERS hehe | 
| BITS | CONTROL | & | UPPER CASE | LOWER CASE | 
SYMBOLS 


7 27 47 67 197 127 147 167 
BEL ETB , 7 G WwW g w 
6 ii i 7 7 V7 23 27 87 67 103 77 11S 
10 30 50 150 170 
BS CAN ( Xx h x 
1060 8 8 | 18 24 | 28 88 68 104 78 120 
11 31 51 7) 111 131 151 71 
HT EM ) 9 Y y 
10606 1 9 9 19 25 29 4) 39 57 49 73 59 89 69 105 79 121 
12 32 52 72 112 132 152 172 
LF SUB * . J Zz j z 
101 86 A 10} 1A 26 | 2A 42 | 3A 58 | 4A 74 5A 390 6A 106 7A 122 
13 33 53 73 113 133 153 173 
VT ESC + 5 K [ k 
10601 =1 B 11] 1B 27 | 2B 43 | 3B 59 | 48 75 5B 91 6B 107 7B 123 
14 34 54 74 114 134 154 174 
FF FS ‘ Vv L \ | ! 
1190 8 Cc 12 | 1C 28 | 2C 44 | 3C 60 | 4C 76 5C 92 | 6C 108 | 7C 124 
15 35 55 75 115 135 155 175 
CR GS - = M ] m 
114 «1 D 13} 1D 29 | 2D 45 | 3D 61 | 4D 77 5D 93 | 6D 109 | 7D 125 
16 36 56 76 116 136 156 176 
so RS é > N A n —_ 
E 14 | 1€ 30 | 2E 46 | 3E 62 | 4E 78 | 5E 94] 6E 110 | 7E 126 
17 37 57 77 117 137 157. 177 
Si us j ? e _ 3 Rubout 
2F 47 | 3F 63 | 4F 79 5F 95 7F 127 
Addressed Universal ‘ Secondary Addresses 
Comnnaands Commands Listen Addresses Talk Addresses én Cacmmands 
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ASCII Control Characters 


acknowledge 

bell 

backspace 

cancel 

carriage return 

playback on, CNTL Q, X-ON 
record on, CNTL R, PUNCH-ON, SOM 
playback off, CNTL S, X-OFF 
record off, CNTL T, PUNCH-OFF, EOM 
delete, rubout 

data link escape 

end of medium 

enquiry 

end of transmission 

escape 

end of transmission block 
end of text 

form feed 

file separater 

group separater 

horizontal tabulation 

line feed 

negative acknowledge 

null 

record separater 

shift in 

shift out 

start of heading 

start of text 

substitute 

synchronous idle 

unit separater 

vertical tab 
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APPENDIX E 
ERROR CODES 
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Table E-1. Error Codes 
| 


DISPLAY 
| SORC/DEST ERR 15 | 
| | 


DESCRIPTION 


Illegal source/ destination key sequence was 
entered. 


COMMAND ERROR 17 


18 
20 
27 

| 


Illegal key sequence while in standard 
Remote Control. 


ILL RAM PAGE The operation would require a 16K RAM 
page change, which the present PAK 


software does not support. 


NONBLANK Device failed the blank test. 


ILLEGAL BIT Not possible to program the device due to 
already programmed locations of incorrect 
polarity. 

PROGRAM FAIL 


22 | The program electronics were unable to 


program the device. 

VERIFY FAIL 7 The device data was incorrect on the first 

| nass of the automatic verify sequence 
during device programming. 

VERIFY FAIL 2 The device data was incorrect on the 

second pass of automatic verify sequence 

during programming. 

NO PROG PAK A device-related operation was attempted 

without any programming module installed. 

PROG PAK RST 


26 | The programming electronics will not start 


operation due to a reset condition. 
RAM EXCEEDED 2/7 | There is insufficient RAM. The total 
allotment of RAM resident is less than the 
word limit or block size, or the begin 
address is set too high. 
ERRORS 


30-39 | These are pak-related errors. 


FRAME ERR The serial interface detected a start bit but 
the stop bit was incorrectly positioned. 
OVERRUN ERR The serial interface received characters 
when the programmer was unable to service 
them. 


Combination of FRAME ERR 41 and 


OVERRUN ERR 42. 


ee 


CORRECTIVE ACTION 


Check key sequence and re-enter. 
Check key sequence and re-enter. 


Either modify Begin RAM or block size so that 
the first and last bytes of the operation reside in 
the same 16K range (0-3FFF, 4000-7FFF, 
8000-BFFF, COO0-FFFF), or contact your local 
Data I/O Service Center for a PAK software 
update. 


Press START to override this error and program 
the device. 


Erase the device if possible or discard it. 


Either the device is bad or the programming 
module is inoperative or out of calibration. 


This error indicates that the device failed the lo 


~ wseasif... thn - Pee. Be east walt Bae we ee 
voltags verify; ihe daia in the part is not ine 


same as the RAM data. 

This error indicates that the device failed the 
high voltage verify; data in the part is not the 
same as the RAM data. 

Install the appropriate programming module. 
Usually an overcurrent caused by an incorrectly 
inserted or bad device. 

Program smaller parts or specific lower 
beginning address. If enough RAM is installed, 
it may be faulty 


Refer to your programming pak manual. 


Check the baud rate and stop bit switches or 
use handshake. 


Check the baud rate and stop bit switches or 


use handshake. 


Check the baud rate and stop bit switches or 
use handshake. 
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Table E-1. Error Codes (Continued) 


DESCRIPTION CORRECTIVE ACTION 


No character (or only nulls and rubouts) Check all connections; then restart operation. 
were received on serial input for 25 seconds | I/O timeout can be disabled by select code F9. 
after pressing the START key, or no 
characters could be transmitted for a period 
of 25 seconds due to the state of the 
handshake lines. 


DISPLAY 


110 TIMEOUT 


FAULTY ACIA 47 | ACIA chip may have failed. Contact your local Data I/O Service Center. 


1/0 OVERRUN 48 | The serial port input buffer received too 
many characters after the handshake line 


informed the sending device to stop. 


Make sure the handshake lines are hooked up 
and operative. 


Incoming data in optional Terminal Remote 
Control (TRC) mode was not recognized by 
the programmer. As a result, data was not 
stored in RAM. 


Check all connections of units in the system 
including serial port cable. Then check to make 
sure you have the correct data format and data 
source, and then try again. 


1/0 VFY FAIL 


The data from the serial port did not match Check and resend the data. 


the data in RAM. 


ERROR This is a Terminal Remote Control (TRC) 
related error that occurs when a begin RAM 
address is below the virtual memory offset, 
or, if the virtual memory offset, 

plus block size exceeds the 29B data RAM 
storage area. Also, a block size of zero will 


cause this error. 


Make sure the beginning RAM address is 

greater or equal to the address offset. Also, 
decrease the block size so that it conforms to 
the RAM size and that it is greater than zero. 


Programmer has not received the 
family and pinout codes for the 
device while in TRC. 


Define the correct family and 
pinout codes for the device. In 

TRC use the “FY’’ command to define the 
family and pinout codes. 


NO RAM There is no working RAM in the 


programmer. 


Replace faulty RAM or have the programmer 
serviced by your local Data I/O Service Center. 


RAM BIT ERR The highest RAM address in the 


programmer is not on a 1K boundary. 


Replace faulty RAM or have the programmer 
serviced by your local Data 1/O Service Center. 


RAM WRITE ERR The programmer is unable to write the 


intended data in RAM. 


Failure of the associated RAM chip; replace the 
failed chip. 


RAM DATA ERR The programmer detected a spurious change 


in RAM data. 


Reload data into RAM. If problem persists, 
service the programmer or notify your local 
Data I/O Service Center. 


The sum-check of software residing 
in the installed programming module is in 
error. 


Contact your local Data |/O Service Center. 


/RQ ERR The IRQ line to the processor was held 


low for no apparent reason. 


Ignore. If the error persists, service the 
programmer. 
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Table E-1. Error Codes (Continued) 


| DISPLAY DESCRIPTION | CORRECTIVE ACTION | 
Programmer received a non-valid command Use the password to release data lock. (See 


67* 
in Computer Remoie Control (CRC). 


i 
| | Masui 


DATA LOCKED 68 | Data locked via Select Function F3. 


ERRORS 70 thru 79 | These are pak-related errors. Refer Refer to your programming pak manual. 

to your programming pak manual. 

ERROR &80* | Incoming data in Terminal Remote Control 
(TRC) has improper parity, checksum or 
data characters (missing or invalid). To 
determine which of these errors apply, use 
TRC command “OA.” 


Wrong parity? Check the 29B parity setting. See 
section 2.5.2. 


Incorrect checksum? Check the connection of 
units in the system, data format, and data 
source, and then try again. 


Improper {missing or invalid) data characters? 
Check the connection of all units in the system, 
data format, and data source, and then try 
again. 


PARITY ERR 87 | The incoming data has incorrect parity. Check the parity switch and try again. 


SUMCHK ERR 82 | The sum-check field received by the Check all connections of units in the system, 
programmer does not agree with its own data format, and data source, and then try 


1 
calculated sum-cneck. For ADSUIl Binary again. 


formats, this error message indicates a 
missing F character. 


COMPOSITE ERR 8&3, | A composite error occurs from any 
85, 86 and 87 | combination of errors 81, 82 and 84. These 
combinations are: 


Error 83 = errors 81 and 82 
Error 85 = errors 81 and 84 
Error 86 = errors 82 and 84 
Error 87 = errors 81, 82 and 84 


INVALID DATA 84 | The programmer received invalid or not 
enough data characters. 
Non-data characters (formats 91-03, 5-9 
12-13) 
Non-hex characters (formats 70, 81, 88, 90) 


Check the connection of all units in the system, 
data format and data source, and then try 
again. 


INVALID FORM 90 | Non-existent |/O format is selected in 
Computer Remote Control (CRC). 


Enter a legal format code. 


1/0 FORM ERR 97 | The programmer received an invalid 
character in the address field. 


Check the connection of all units in the system 
data format, and data source, and then try 
again. 


!/O FORM ERR 92 | The address check was in error (Signetics 


Trann and T, ktronix = 


LwVilA ts 


Check the connection of units in the system, 
data format, and data source, and then try 


Soviet, 


xadecima! formats 


€ 


only). again. 
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Table E-1. Error Codes (Continued) 


DISPLAY DESCRIPTION : CORRECTIVE ACTION 


BLOCK MOVE ERR’ 97 | Block Move was attempted outside RAM Redefine parameters. 
boundaries. 


DEV EXCEEDED 98 | Programming data exceeded the last device Redefine parameters. 
address. 


ERRORS ~~ AO thru AQ | These are pak-related errors. Refer to your Refer to your programming pak manual. 
programming pak manual. 


1/0 FORM ERR 93 | The number of input records did not equal Check the connection of all units in the system, 
the Record Count (MOS Technology format data format, and data source, and then try 
only). again.) 


BAD REC TYPE 94 | The record type was in error. (Intel- Check the connection of all units in the system, 
Intellec 8/MDS, intel MCS-86 and T.1. data format, and data source, and then try 
SDSMAC formats only.) again. 


illegal center point for RAM shuffle. Check parameters and re-enter. 


*Remote Control only; will not occur during front panel operation, hence no front panel display. 
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APPENDIX F 
SCHEMATICS 


Controller Board 30-701-0047 
Front Panel Keyboard 30-702-1648 
Front Panel Display Driver 30-702-0061 
FIP Display Board 30-702-0060 
128K Memory Expansion Board 30-701-1636 
Handler Interface Board 30-702-1984 (optional) 
Filter Board 30-701-1672 
CAUTION 


When servicing Data I/O equipment 
beyond that described in this manual, 
we recommend that you send your 
unit to your local service center. If 
you decide to do the repair be aware 
that many parts in Data I/O equip- 
ment have been qualified by vendor 
and may not be interchangeable with 
the same type of part manufactured 
elsewhere. Refer to the back of this 
manual for service office locations. 
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